static_pages.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>加载静态内容 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/tutorial/static_pages.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  27. <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;<a href="index.html">教程</a>&nbsp;&#8250;&nbsp;加载静态内容 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>教程 &minus; 加载静态内容</h1>
  61. <p class="important"><strong>注意:</strong> 本教程假定你已经下载和<a href="../installation/index.html">安装</a>了CodeIgniter开发环境。</p>
  62. <p>首先,你需要创建一个可以处理静态内容请求的<strong>控制器</strong>类。控制器,是一个用来代理完成某项任务的PHP类,它充当基于MVC架构应用程序的“粘合剂”(译者注:控制器用来粘合/协调不同模型和视图。随着教程的深入,你会更深刻的理解这一点)。</p>
  63. <p>举例来说,假设存在某个针对如下URL的请求: <code>http://example.com/news/latest/10</code> 仔细观察此URL地址,我们可以猜测它所完成的任务:存在某个类名为&quot;news&quot;的控制器,调用此类下的&quot;latest&quot;方法用来提取10条最新新闻,然后解析显示在最终浏览器页面上。在基于MVC架构思想的应用程序中,我们经常会见到如下典型URL格式:
  64. <code>http://example.com/[控制器类名]/[控制器方法名]/[所需参数]</code>
  65. 在实际项目中,以上典型格式可能会存在变化趋于复杂。但到目前为止,了解这一典型格式已然足够。</p>
  66. <p>创建一个控制器文件<dfn>application/controllers/pages.php</dfn>,并编写如下代码:</p>
  67. <textarea class="textarea" style="width:100%" cols="50" rows="10">
  68. &lt;?php
  69. class Pages extends CI_Controller &#123;
  70. public function view($page = 'home')
  71. &#123;
  72. &#125;
  73. &#125;
  74. </textarea>
  75. <p>你已经创建了一个名为&quot;pages&quot;的类, 包含一个名为&quot;view&quot;的方法,并定义了一个名为 <var>$page</var> 的参数。
  76. 这个pages类继承了CI_Controller类。这就意味着
  77. 这个新的pages类可以继承CI_Controller
  78. (<dfn>system/core/Controller.php</dfn>) 类里面定义的方法和变量。</p>
  79. <p><strong>这个控制器会成为你的网站程序每次请求的中心</strong>。
  80. 在非常技术性的CodeIgniter的讨论中,我们把它称为 <em>超级对象</em>。就像任何php类一样,在你自己的控制器中,使用$this来调用它,这样就可以实现用 <var>$this</var> 来加载所有变量、视图和对这个框架进行一般操作。
  81. <p>现在你已经创建了自己的第一个方法,是时候来做几个基础的页面模板了。我们将要创建两个 &quot;视图&quot; (模板页面) ,也就是页面的页头(header)和页脚(footer)。</p>
  82. <p>创建页头文件 <dfn>application/views/templates/header.php</dfn> ,代码如下。</p>
  83. <textarea class="textarea" style="width:100%" cols="50" rows="8">
  84. &lt;html&gt;
  85. &lt;head&gt;
  86. &lt;title&gt;&lt;?php echo $title ?&gt; - CodeIgniter 2 Tutorial&lt;/title&gt;
  87. &lt;/head&gt;
  88. &lt;body&gt;
  89. <h1>CodeIgniter 2 Tutorial</h1>
  90. </textarea>
  91. <p>页头文件包括在正式加载视图前需要的基本的HTML代码。同时,这里还输出了 <var>$title</var> 变量,一会儿我们会在控制器中对它进行定义。现在我们来创建一个页脚 <dfn>application/views/templates/footer.php</dfn> ,代码如下:</p>
  92. <textarea class="textarea" style="width:100%" cols="50" rows="4">
  93. <strong>&#38;copy; 2011</strong>
  94. &lt;/body&gt;
  95. &lt;/html&gt;
  96. </textarea>
  97. <h2>为控制器添加逻辑结构 (Adding logic to the controller)</h2>
  98. <p>之前你创建了一个控制器并定义了一个方法view()。这个方法里定义了一个参数,它的值是即将加载的页面的名称。静态页面的模板将被放在 <dfn>application/views/pages/</dfn> 文件夹中。</p>
  99. <p>在那个文件夹中需要创建两个文件,分别为 <dfn>home.php</dfn> 和 <dfn>about.php</dfn>。在这两个文件中敲一些任何你喜欢的内容进去并保存。如果你喜欢特别不寻常的内容,可以试试敲“Hello World!”。</p>
  100. <p>为了能加载那些页面,你需要检查一下它们是否存在:</p>
  101. <pre>
  102. public function view($page = 'home')
  103. &#123;
  104. if ( ! file_exists(APPPATH.'/views/pages/'.$page.'.php'))
  105. &#123;
  106. // 页面不存在
  107. show_404();
  108. &#125;
  109. $data['title'] = ucfirst($page); // 将title中的第一个字符大写
  110. $this-&gt;load-&gt;view('templates/header', $data);
  111. $this-&gt;load-&gt;view('pages/'.$page, $data);
  112. $this-&gt;load-&gt;view('templates/footer', $data);
  113. &#125;
  114. </pre>
  115. <p>此时,如果页面存在,它将被加载,同时,页头和页脚也会显示出来。如果页面不存在,那么就会显示404错误页面。</p>
  116. <p>这个方法中的第一行是检查文件是否存在的,使用的是PHP自带的函数 <var>file_exists()</var> 。<var>show_404()</var> 是CodeIgniter中的函数,用来调用404错误页面。</p>
  117. <p>在页头模板(header.php)中,我们用 <var>$title</var> 变量来自定义页面标题(&lt;title&gt;)。而这个变量的值,我们现在在这个方法中对它进行了定义。不过,我们并没有将这个值直接赋给变量,而是将它作为一个元素赋给了 <var>$data</var> 数组。</p>
  118. <p>最后一项,按照需要显示的顺序来加载那些视图。 <var>view()</var> 方法中的第二个参数是用来传递值给视图的。数组中的每个值都被定义成与它关键字相同的一个变量,如控制器中 <var>$data['title']</var> 的值就等同于视图中变量$title。<p>
  119. <h2>设置路由(Routing)</h2>
  120. <p>这个控制器现在可以工作了,在浏览器中键入后面的地址 <dfn>[你的网址]index.php/pages/view</dfn> 就可以看到Home页面。输入 <dfn>index.php/pages/view/about</dfn> 也可以看到about页面,也是带页头和页脚的哦。</p>
  121. <p>根据自定义路由的规则,你也可以自己定义任何控制器和方法的URI,这样就可以摆脱下面的既定规则了。
  122. <code>http://example.com/[controller-class]/[controller-method]/[arguments]</code></p>
  123. <p>我们来试试吧。打开路由文件 <dfn>application/config/routes.php</dfn> ,并添加下面两行代码,并删除 <var>$route</var> 数组中的其他代码。</p>
  124. <pre>
  125. $route['default_controller'] = 'pages/view';
  126. $route['(:any)'] = 'pages/view/$1';
  127. </pre>
  128. <p>CodeIgniter由上而下读取路由规则然后将请求路由至第一个匹配的规则。每一个规则都是一个正则表达式(左侧)映射到一个由斜线分隔的控制器和方法名(右侧)。当有请求到来时,CodeIgniter寻找第一个匹配的路由规则,然后调用相应的控制器和方法,通常还带着参数。</p>
  129. <p>更多关于路由设置的信息都在 URI 路由 <a href="../general/routing.html">文档</a> 里。</p>
  130. <p>回到上面的代码,第二行是指利用通配符 <dfn>(:any)</dfn> 可以使任何请求都能匹配到 <var>$routes</var> 数组,并且通过参数传递给pages类的view()方法。</p>
  131. <p>现在,访问下 <dfn>index.php/about</dfn>. 看看是不是已经能正确地显示页面了呢?赞!</p><p>&nbsp;</p>
  132. <div id="Contributors">
  133. 翻译贡献者:
  134. aolinks, borisauschina, changekale, cnsaturn, csfhc, Hex, irini, lionskys, liuzhengyi, ljhljh235, syrdxb, zzdjk6</div>
  135. <div id="DocDate">
  136. 最后修改: 2014-06-10 14:12:28</div>
  137. </div>
  138. <!-- END CONTENT -->
  139. <div id="footer">
  140. <p>
  141. 上一个主题:&nbsp;&nbsp;<a href="index.html">内容提要</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  142. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="news_section.html">读取新闻条目</a> </p>
  143. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  144. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  145. </div>
  146. </body>
  147. </html>