Skip to content

Modularity in CodeIgniter PHP5

Derek Jones edited this page Jul 5, 2012 · 13 revisions

Plugin Introduction

I've become sick and tired of CodeIgniter's $this-centeredness and I want to use static PHP5 classes to access core CodeIgniter objects such as libraries, models, view, and db. So, I have written a very simple set of wrapper classes.

Advantages:

  • No more calling get_instance() when you need to access the framework inside a model, library, helper, or view
  • No more manual loading of libraries, models, or databases
  • More concise syntax
  • Support for multiple database connections

Requirements:

  • CodeIgniter 1.5+
  • PHP5+

Installation: This is a plugin so no core hacking is required. Simply download [url=http://codeigniter.com/wiki/5db90a196965c9991afabcf9e66726f6/]modular_11.zip[/url] and extract it into your application/plugins folder. Load it just like any other plugin.

How to use the Modularity Plugin

Views

# Display a view -- old way
$this->load->view('myview', $data);
# new way
View::show('myview', $data);

# Load a view into a string variable -- old way
$pagetext = $this->load->view('myview', $data, TRUE);
# new way
$pagetext = View::parse('myview', $data);

Libraries

# Do something with a library -- old way
$this->load->library('mylibrary');
$this->library->do_something();

# new way
Libs('mylibrary')->do_something();  // the library automatically loads if needed

Models

# Fetch data with a model -- old way
$this->load->model('mydatamodel');
$this->mydatamodel->do_something();

# new way
Models('mydatamodel')->do_something();  // the model automatically loads if needed

Databases

# Query a database -- old way (default database)
$this->load->database();
$query = $this->db->query($sql);

# new way
$query = DB()->query($sql);  // the database automatically loads if needed

# Query a database -- old way (multiple connections)
$dbh1 = $this->load->database('db1', TRUE);
$dbh2 = $this->load->database('db2', TRUE);
$query1 = $dbh1->query($sql);
$query2 = $dbh2->query($sql);

# new way
$query1 = DB('db1')->query($sql);
$query2 = DB('db2')->query($sql);

Inside libraries, helpers, or views

# old way
$CI =& get_instance();
$CI->load->model('mymodel');
$CI->mymodel->do_something();

# new way -- no calling get_instance()!
Models('mymodel')->do_something();
Clone this wiki locally