Professional CodeIgniter, Thomas Myer
Chapter 1: Welcome to the MVC World
20
Note the two additions to the
index()
method: loading the parser library and then calling the parser,
passing in as arguments the name of the view and the data retrieved from the model. Also note that the
data from the model can be safely stored in the
data from the model can be safely stored in the
$data
array (which has also helpfully been initialized).
In the view, you ' ll name your pseudo - variables from the keys of this array, which helpfully map to the
names of the database table fields. For example,
names of the database table fields. For example,
$data[
`
css
'
]
can be accessed with
{css}
.
Modifying the View
Here ' s the view, with pseudo - variables in place instead of real PHP variables.
<
html
>
<
head
>
<
title{title}
<
/title
>
<
link href="{css}" rel="stylesheet" type="text/css"/
>
<
meta name="keywords" value="{keywords}"/
>
<
meta name="description" value="{description}"/
>
<
/head
>
<
body
>
<
h1
>
{title}
<
/h1
>
<
p
>
{bodycopy}
<
/p
>
<
/body
>
<
/html
>
This approach certainly involves a lot less typing, and the overall aesthetics can be very familiar and
pleasing to anyone who ' s worked with a template system in the past. Also, some HTML specialists who
are unfamiliar with PHP find this format a bit easier to work with.
What about
{bodycopy}
?
However, notice that the
{bodycopy}
pseudo - variable in the example has lost some of its functionality.
In the previous PHP incarnation of this template, the bodycopy data were processed via
nl2br()
, a PHP
function that converts line breaks into HTML
<
br/
>
tags.
One way to fix the problem is to add two lines of processing to your controller, like so:
function index(){
$data = array();
$this-
>
load-
>
library(`parser');
$this-
>
load-
>
model(`Page_model','',TRUE);
$data = $this-
>
Page_model-
>
fetchHomePage();
//fix the body copy
$fixcopy = nl2br($data[`bodycopy']);
$data[`bodycopy'] = $fixcopy;
$this-
>
parser-
>
parse(`home',$data);
}
Of course, you could also rewrite the model, replacing
row_array()
with
row()
and then processing
each field as it comes off the database query. That way you can process every element as it is extracted
from the database.
from the database.
c01.indd 20
c01.indd 20
6/10/08 5:30:03 PM
6/10/08 5:30:03 PM