视图用于展示页面内容,控制器通过$this->load->view()加载视图并传递数据;可使用数组或对象向视图传递动态内容,支持多次调用加载多个视图组件,提升布局复用性与维护性。

在CodeIgniter中,视图是用于展示页面内容的PHP文件,通常包含HTML和少量PHP代码。控制器负责加载视图,并可将数据传递给视图进行动态渲染。下面详细介绍视图的加载方式以及如何向视图传递数据。
直接加载视图
最简单的加载方式是使用$this->load->view()方法。该方法接受视图文件名作为参数,默认从application/views/目录下查找文件。
例如,有一个视图文件 application/views/welcome.php,可以在控制器中这样加载:
public function index()
{
$this->load->view('welcome');
}
注意:视图文件扩展名.php可以省略。
向视图传递数据
要让视图显示动态内容,需要从控制器传递数据。有两种常用方式:
-
使用关联数组:
$data = array( 'title' => '欢迎页面', 'content' => '这是首页内容' ); $this->load->view('welcome', $data);在视图中可以直接使用$title和$content变量。 -
使用对象:
$data = new stdClass(); $data->title = '欢迎页面'; $data->content = '这是首页内容'; $this->load->view('welcome', $data);视图中仍可通过$title等变量访问。
加载多个视图
实际开发中常将页面拆分为头部、侧边栏、内容区和底部等部分。可以通过多次调用view()来组合页面。
public function index()
{
$data['title'] = '首页';
$this->load->view('header', $data);
$this->load->view('sidebar');
$this->load->view('content', $data);
$this->load->view('footer');
}
这种方式便于维护和复用布局组件。
启用模板解析(可选)
CodeIgniter支持伪变量语法(如{{ title }}),需启用模板解析器:
$this->load->library('parser');
$this->parser->parse('welcome', $data);
这适合不想在视图中写PHP代码的场景,但性能略低于原生PHP输出。
基本上就这些。掌握视图加载和数据传递是开发CodeIgniter应用的基础,合理组织视图结构能提升项目可维护性。










