视图
简而言之,一个视图就是一个网页,或是网页的部分,如头部,底部,侧边栏等等。事实上,如果你需要这种层次类型,视图可以很灵活的嵌入到其他视图中。
视图从不直接调用,必须被一个控制器来调用。记住,在一个 MVC 框架中,控制器扮演着交通警察的角色,那么,他有责任去取回某一特定的视图。如果你还没有阅读过控制器页面的话,你应该事先阅读控制器页面。
下面使用你在控制器页面已经创建过的示例控制器,让我们来给他添加个视图。
创建视图
使用你的文本编辑器,创建一个名为 blogview.php 的文件,写入以下代码:
然后保存文件到 application/views/ 文件夹。
载入视图
你必须使用下面的函数来载入一个视图文件:
$this->load->view('name');
上面的 name 便是你的视图文件的名字。注意:.php 文件的扩展名(后缀名)没有必要专门写出,除非你使用了其他的扩展名。
现在, 打开你先前写的名为 blog.php 控制器文件,并且使用视图载入函数替换echo段代码:
如果你使用先前你用的 URL 浏览你的网站,你将会看到你的新视图. URL 与下面的类似:
example.com/index.php/blog/
载入多个视图
CodeIgniter 能智能的处理多个从控制器发起的视图载入函数调用 $this->load->view。如果有多个调用,那么他们将会被合并到一起。例如,你可能希望有一个标题视图、一个菜单视图、一个内容视图、和一个页脚视图。他们看起来应该是这样:
<?php
class Page extends CI_Controller {
function index()
{
$data['page_title'] = 'Your title';
$this->load->view('header');
$this->load->view('menu');
$this->load->view('content', $data);
$this->load->view('footer');
}
}
?>
在上面的例子中,我们使用了“动态添加数据”,你将在下面看到。
用子文件夹存储视图
如果你想让文件更有组织性,你也可以用子文件夹来存储你的视图文件. 当你在载入视图时,必须加上子文件夹的名字. 示例如下:
$this->load->view('folder_name/file_name');
给视图添加动态数据
数据通过控制器以一个数组或是对象的形式传入视图 , 这个数组或对象作为视图载入函数的第二个参数 .下面便是使用数组的示例:
$data = array(
'title' => 'My Title',
'heading' => 'My Heading',
'message' => 'My Message'
);
$this->load->view('blogview', $data);
这里是使用对象的示例:
$data = new Someclass();
$this->load->view('blogview', $data);
当我们一次性载入多个视图的时候,你只需在第一个视图传入数据就可以了(header视图显示title,content视图显示message),比如:
<?php
class Page extends CI_Controller {
function index()
{
$data['title'] = 'Your title';
$data['message'] = 'Your message';
$this->load->view('header',$data);
$this->load->view('content');
$this->load->view('footer');
}
}
?>
注意:如果你使用一个对象,那么类变量将转换为数组元素。
好了,让我们用你的控制器试试。打开控制器并添加以下代码:
现在,打开你的视图文件,将其中的文本替换成与数组对应的变量:
然后使用你先前用过的URL载入页面,你将看到变量已经被替换。
创建循环
你传入视图文件的数据,不仅仅局限于简单的变量。你可以传递多维数组。例如:你从数据库里面取出数据就是典型的多维数据。
这里是个简单的示例。添加以下代码到你的控制器:
现在打开你的视图文件,创建一个循环:
注意: 上面的例子中我们使用PHP替代语法。如果你对这种语法不熟悉,可以在这里阅读。
获取视图内容
view函数第三个可选参数可以改变函数的行为,让数据作为字符串返回而不是发送到浏览器。如果想用其它方式对数据进一步处理,这样做很有用。如果将view第三个参数设置为
$string = $this->load->view('myfile', '', true);
例子:有些情况下,你并不想直接输出视图,而是仅仅想得到视图的内容以备后用。那么可以参考如下代码。
view方法中的第三个参数表示不输出视图,而只是将结果返回给一个变量。