directory search
欢迎 目录 快速参考图 基本信息 服务器要求 许可协议 变更记录 关于CodeIgniter 安装 下载 CodeIgniter 安装指导 从老版本升级 疑难解答 介绍 开始 CodeIgniter 是什么? CodeIgniter 速记表 支持特性 应用程序流程图 模型-视图-控制器 架构目标 教程 内容提要 加载静态内容 创建新闻条目 读取新闻条目 结束语 常规主题 CodeIgniter URL 控制器 保留字 视图 模型 辅助函数 使用 CodeIgniter 类库 创建你自己的类库 使用 CodeIgniter 适配器 创建适配器 创建核心系统类 钩子 - 扩展框架的核心 自动装载资源 公共函数 URI 路由 错误处理 缓存 调试应用程序 以CLI方式运行 管理应用程序 处理多环境 PHP替代语法 安全 开发规范 类库参考 基准测试类 日历类 购物车类 配置类 Email 类 加密类 文件上传类 表单验证详解 FTP 类 图像处理类 输入类 Javascript 类 语言类 装载类 迁移类 输出类 分页类 模板解析器类 安全类 Session 类 HTML 表格类 引用通告类 排版类 单元测试类 URI 类 User-Agent 类 表单验证 XML-RPC 和 XML-RPC 服务器 Zip 编码类 缓存适配器 适配器参考 适配器 数据库类 Active Record 类 数据库缓存类 自定义函数调用 数据库配置 连接你的数据库 数据库快速入门例子代码 字段数据 数据库维护类 查询辅助函数 数据库类 查询 生成查询记录集 表数据 事务 数据库工具类 JavaScript类 辅助函数参考 数组辅助函数 CAPTCHA 辅助函数 Cookie Helper 日期辅助函数 目录辅助函数 下载辅助函数 Email 辅助函数 文件辅助函数 表单辅助函数 HTML辅助函数 Inflector 辅助函数 语言辅助函数 数字辅助函数 路径辅助函数 安全辅助函数 表情辅助函数 字符串辅助函数 文本辅助函数 排版辅助函数 URL 辅助函数 XML 辅助函数
characters

CodeIgniter 用户指南 版本 2.1.0

编辑文档、查看近期更改请 登录 或 注册  找回密码
查看原文

教程 − 加载静态内容

注意:本教程假定你已经下载和安装了CodeIgniter开发环境。

首先,你需要创建一个可以处理静态内容请求的控制器类。控制器,是一个用来代理完成某项任务的PHP类,它充当基于MVC架构应用程序的“粘合剂”(译者注:控制器用来粘合/协调不同模型和视图。随着教程的深入,你会更深刻的理解这一点)。

举例来说,假设存在某个针对如下URL的请求:http://example.com/news/latest/10仔细观察此URL地址,我们可以猜测它所完成的任务:存在某个类名为"news"的控制器,调用此类下的"latest"方法用来提取10条最新新闻,然后解析显示在最终浏览器页面上。在基于MVC架构思想的应用程序中,我们经常会见到如下典型URL格式:http://example.com/[控制器类名]/[控制器方法名]/[所需参数]在实际项目中,以上典型格式可能会存在变化趋于复杂。但到目前为止,了解这一典型格式已然足够。

创建一个控制器文件application/controllers/pages.php,并编写如下代码:

你已经创建了一个名为"pages"的类, 包涵一个视图的方法,并定义了一个名为$page的参数。 这个pages类继承了CI_Controller类。这就意味着 这个新的pages类可以继承CI_Controller (system/core/Controller.php) 类里面定义的方法和变量。

这个控制器会成为你的网站程序每次请求的中心。 在非常技术性的CodeIgniter的讨论中,我们把它称为超级对象。就像任何php类一样,在你自己的控制器中,使用$this来调用它,这样就可以实现用$this来加载所有变量、视图和对这个框架进行一般操作。

现在你已经创建了自己的第一个方法,是时候来做几个基础的页面模板了。我们将要创建两个 "视图" (模板页面) ,也就是页面的页头(header)和页脚(footer)。

创建页头文件application/views/templates/header.php,代码如下。

页头文件包括在正式加载视图前需要的基本的HTML代码。同时,这里还输出了$title函数,一会儿我们会在控制器中对它进行定义。现在我们来创建一个页脚application/views/templates/footer.php,代码如下:

为控制器添加逻辑结构 (Adding logic to the controller)

之前你创建了一个控制器并定义了一个方法view()。这个方法里定义了一个参数,它的值是即将加载的页面的名称。静态页面的模板将被放在application/views/pages/文件夹中。

在那个文件夹中需要创建两个文件,分别为home.phpabout.php。在这两个文件中敲一些任何你喜欢的内容进去并保存。如果你喜欢特别不寻常的内容,可以试试敲“Hello World!”。

为了能加载那些页面,你需要检查一下它们是否存在:

public function view($page = 'home') { if ( ! file_exists('application/views/pages/'.$page.'.php')) { // 页面不存在 show_404(); } $data['title'] = ucfirst($page); // 将title中的第一个字符大写 $this->load->view('templates/header', $data); $this->load->view('pages/'.$page, $data); $this->load->view('templates/footer', $data); }

此时,如果页面存在,它将被加载,同时,页头和页脚也会显示出来。如果页面不存在,那么就会显示404错误页面。

这个方法中的第一行是检查文件是否存在的,使用的是PHP自带的函数file_exists()show_404()是CodeIgniter中的函数,用来调用404错误页面。

在页头模板(header.php)中,我们用$title变量来自定义页面标题()。而这个变量的值,我们现在在这个方法中对它进行了定义。不过,我们并没有将这个值直接赋给变量,而是将它作为一个元素赋给了<var>$data</var>数组。</p> <p>最后一项,按照需要显示的顺序来加载那些视图。<var>view()</var>方法中的第二个参数是用来传递值给视图的。数组中的每个值都被定义成与它关键字相同的一个变量,如控制器中<var>$data['title']</var>的值就等同于视图中变量$title。</p> <p></p> <h2>设置路由(Routing)</h2> <p>这个控制器现在可以工作了,在浏览器中键入后面的地址<dfn>[你的网址]index.php/pages/view</dfn>就可以看到。输入<dfn>index.php/pages/view/about</dfn>也可以看到about页面,也是带页头和页脚的哦。</p> <p>根据自定义路由的规则,你也可以自己定义任何控制器和方法的URI,这样就可以摆脱下面的既定规则了。<code>http://example.com/[controller-class]/[controller-method]/[arguments]</code></p> <p>我们来试试吧。打开路由文件<dfn>application/config/routes.php</dfn>,并添加下面两行代码,并删除<var>$route</var>数组中的其他代码。</p> <pre>$route['default_controller'] = 'pages/view'; $route['(:any)'] = 'pages/view/$1';</pre> <p>在CodeIgniter里,路由规则是按照从上到下的顺序读取的,而其中设定路由的请求是第一个被读到的。没有规则从左到右都是 控制器名斜线(/)方法名 的组合。请求出现的时候,CodeIgniter就开始最合适的内容进行匹配,调用适当的控制器和方法,也可能调用参数。</p> <p>更多关于路由设置的信息都在 URI 路由 文档 里。</p> <p>回到上面的代码,第二行是指利用通配符<dfn>(:any)</dfn>可以使任何请求都能匹配到<var>$routes</var>数组,并且通过参数传递给pages类的view()方法。</p> <p>现在,访问下<dfn>index.php/about</dfn>. 看看是不是已经能正确地显示页面了呢?赞!</p> <p></p> <div id="Contributors"> 翻译贡献者: borisauschina, cnsaturn, Hex, irini, syrdxb, zzdjk6 </div> <div id="DocDate"> 最后修改: 2012-04-23 09:47:38 </div> </div> <!-- END CONTENT --> <div id="footer"> <p>上一个主题: 内容提要 · 页首 · 用户指南首页 · 下一个主题: 读取新闻条目</p> <p>CodeIgniter · 版权所有 © 2006-2012 · Ellislab, Inc.</p> <p>中文化: CodeIgniter 中国 · 制作: Hex · 版本: 1.30 · 鸣谢: 子非鱼</p> </div> <div style="display:none"> <noscript> <img alt="我要啦免费统计" src="//m.sbmmt.com/../webimg.m.sbmmt.com/go.asp-svid=5&id=3289908&style=-1&vpage=http---codeigniter.org.cn-user_guide-toc.html&35213.39.gif" tppabs="http://img.users.m.sbmmt.com/3289908.asp" style="border:none"> </noscript> </div> </div> <div class="view-foot"> <div class="article-jump"> <span class="jump-up">Previous article:<a></a></span> <span class="jump-down">Next article:<a></a></span> </div> <a class="view-backtop"><i class="icon-arrow-up2"></i></a> </div> </div> </div> </div> </div> </div> </div> <!--<i class="loading-image"> </i>--> <div id="languageslayer" style="display:none" class="flexColumn languageslayer"> <div class="lan-con"> <a href="javascript:;" onclick="setlang($(this))" data-value="zh-cn" class="chooselan ">简体中文(ZH-CN)</a> <a href="javascript:;" data-value="en" class="chooselan checklan">English(EN)</a> <a href="javascript:;" onclick="setlang($(this))" data-value="zh-tw" class="chooselan ">繁体中文(ZH-TW)</a> <a href="javascript:;" onclick="setlang($(this))" data-value="ja" class="chooselan ">日本語(JA)</a> <a href="javascript:;" onclick="setlang($(this))" data-value="ko" class="chooselan ">한국어(KO)</a> <a href="javascript:;" onclick="setlang($(this))" data-value="ms" class="chooselan ">Melayu(MS)</a> <a href="javascript:;" onclick="setlang($(this))" data-value="fr" class="chooselan ">Français(FR)</a> <a href="javascript:;" onclick="setlang($(this))" data-value="de" class="chooselan ">Deutsch(DE)</a> </div> </div> <div style="display:none"></div> </body> </html>