CI框架篇之视图篇--载入(1)
创建视图
创建视图文件很简单,只需要建立后缀名为‘.php’的文件,
然后保存文件到 application/views/ 文件夹即可
当然,随着工程的大小,你有必要对很多的视图根据控制器进行归类,
然后分不同的文件夹存储:
例如: application/views/home 表示定义的前台主视图
application/views/admin 表示定义的后台主视图
载入视图
一个视图就是一个网页,或是网页的部分,如头部,底部,侧边栏等等。事实上,如果你需要
这种层次类型,视图可以很灵活的嵌入到其他视图中。
视图从不直接调用,必须被一个控制器来调用。记住,在一个 MVC 框架中,控制器扮演着
交通警察的角色,那么,他有责任去取回某一特定的视图。如果你还没有阅读过控制器页面
的话,你应该事先阅读控制器页面。
下面使用你在控制器页面已经创建过的示例控制器,让我们来给他添加个视图。
使用下面的函数来载入一个视图文件:$this->load->view('name');
这里的原理是:
通过继承基类,然后调用load类,本身的类就继承了CI的超级对象 ,将素有的类所谓了他的属性进行使用
难以理解的话,可以这样理解:
$this->load->view()的原理就是
CI_Loader 这个是 关于变量加载的类
$obj = New CI_Loader
$this->load = $obj;(这个会自动实例化这个对象,放在CI_Controller下,)
$this->load->view();
name 便是你的视图文件的名字(.php 文件的扩展名(后缀名)没有必要专门写出)
载入多个视图
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); //这里调用content模板的同时,将变量分配给了视图文件
$this->load->view('footer');
}
}
?>
用子文件夹存储视图
当你用文件夹来存储你的视图文件.. 载入视图时,必须加上子文件夹的名字. 示例如下:
$this->load->view('folder_name/file_name');
给视图添加动态数据
将控制器的数据添加到视图的时候,可以是任意的基本数据类型,和复合数据类型,对象或者数组都支持
<?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');
}
}
?>
通过动态的将值给视图,然后在视图通过通过调用该数组的‘$+键名’进行调用
注意:这里的调用可能是大学所熟悉的smarty 和thinkphp有很大的不同。原来学到的引擎
在分配单个变量的时候可能是多次的调用assgin方法,这里不同,因为这里是调用模板的同时赋值给视图
你只能将所有需要的值通过数组然后给视图,因为这里一个视图只能调用一次,调用多次就会出现很多的
重复的页面
获取视图内容
view函数第三个可选参数可以改变函数的行为,让数据作为字符串返回而不是发送到浏览器。
如果想用其它方式对数据进一步处理,这样做很有用。如果将view第三个参数设置为true(布尔)
则函数返回数据。view函数缺省行为是 false, 将数据发送到浏览器。如果想返回数据,
记得将它赋到一个变量中:
$buffer = $this->load->view('blogview', $data, true);
view方法中的第三个参数表示不输出视图,而只是将结果返回给一个变量。
CI框架篇之视图篇--载入(1)的更多相关文章
- php ci框架中载入css和js文件失败的原因及解决方法
在将html页面整合到ci框架里面的时候,载入css和js失败. 原因是ci框架是入口的框架 对框架中文件的全部请求都须要经过index.php处理完毕,当载入外部的css和js文件的时候要使 用ba ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...
- 初学后台框架总结篇二——快速了解CI框架
一.下载CI框架并安装,这里放置一张自己的项目目录结构图 目录框架搭建好之后开始将自己的项目与框架融合 二.更改相关配置 1.用任何文本编辑器打开 application/config/config. ...
- iOS系列 基础篇 05 视图鼻祖 - UIView
iOS系列 基础篇 05 视图鼻祖 - UIView 目录: UIView“家族” 应用界面的构建层次 视图分类 最后 在Cocoa和Cocoa Touch框架中,“根”类时NSObject类.同样, ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文 下一篇:Farseer.net轻量级ORM开源框 ...
随机推荐
- 制作LOGO的35种方法
A logo design is really a graphical element (ideogram, symbol, emblem, icon, sign) that, along with ...
- asp.net中bin目录下的 dll.refresh文件
首先找到了这篇文章http://www.cnblogs.com/haokaibo/archive/2010/07/31/1789342.html 然后找到一篇英文的文章http://monsur.xa ...
- Learning WCF Chapter2 Service Description
While messaging protocols are responsible for message serialization formats,there must be a way to c ...
- Java序列化技术
Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化? Java序列化是指把Java对象转换为字节序列的过程:而Java反序列化是指把字节序列恢复为Java对象 ...
- 【转】Android 4.2蓝牙介绍
原文网址:http://blog.csdn.net/innost/article/details/9187199 Tieto公司某蓝牙大牛写得<程序员>投稿文章 Android 4.2蓝牙 ...
- Selenium - WebDriver 小结(1)
public class Base { SimpleDateFormat formatterTime = new SimpleDateFormat("yyyyMMdd_hhmmssa&quo ...
- 作品第一课----改变DIV样式属性
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 1115 HTML CSS
1. HTML 全称HyperText Markup Language (超文本标记语言). 2. 网页=HTML文件 + Web服务器 + CSS文本. 3. Web服务器:处理浏览器请求,寻找资源 ...
- 使用GitHub管理源代码
作为一个开发员,源码的管理是一个头等大事来的,想象一下,修改完成却发现文件丢失了,该怎么办?有了源代码管理工具,能够帮助我们查看某个代码文件的修改内存及历史修改记录. 作为.Net开发员,我使用过VS ...
- MongoDB库设计原则及实践
MongoDB数据模型选择• CAP定理(Consistency ,Availability 和Partition Tolerance )– Consistency(一致性):数据一致更新,所有数据变 ...