views.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  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/general/views.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;视图 </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>视图</h1>
  61. <p>简而言之,一个<dfn>视图</dfn>就是一个网页,或是网页的部分,如头部,底部,侧边栏等等。事实上,如果你需要这种层次类型,视图可以很灵活的嵌入到其他视图中。</p>
  62. <p>视图从不直接调用,必须被一个<a href="controllers.html">控制器</a>来调用。记住,在一个 MVC 框架中,控制器扮演着交通警察的角色,那么,他有责任去取回某一特定的视图。如果你还没有阅读过控制器页面的话,你应该事先阅读<a href="controllers.html">控制器</a>页面。</p>
  63. <p>下面使用你在<a href="controllers.html">控制器</a>页面已经创建过的示例控制器,让我们来给他添加个视图。</p>
  64. <h2>创建视图</h2>
  65. <p>使用你的文本编辑器,创建一个名为 <dfn>blogview.php </dfn>的文件,写入以下代码:</p>
  66. <p><textarea cols="50" rows="10" style="width: 100%;" class="textarea">
  67. &lt;html&gt;
  68. &lt;head&gt;
  69. &lt;title&gt;My Blog&lt;/title&gt;
  70. &lt;/head&gt;
  71. &lt;body&gt;
  72. <h1>Welcome to my Blog!</h1>
  73. &lt;/body&gt;
  74. &lt;/html&gt;
  75. </textarea></p>
  76. <p>然后保存文件到 <dfn>application/views/</dfn> 文件夹。</p>
  77. <h2>载入视图</h2>
  78. <p>你必须使用下面的函数来载入一个视图文件:</p>
  79. <p><code>$this-&gt;load-&gt;view('<var>name</var>');</code></p>
  80. <p>上面的 <var>name</var> 便是你的视图文件的名字。注意:.php 文件的扩展名(后缀名)没有必要专门写出,除非你使用了其他的扩展名。</p>
  81. <p>现在, 打开你先前写的名为 <dfn>blog.php</dfn> 控制器文件,并且使用视图载入函数替换echo段代码:</p>
  82. <p><textarea cols="50" rows="10" style="width: 100%;" class="textarea">&lt;?php
  83. class Blog extends CI_Controller &#123;
  84. function index()
  85. &#123;
  86. $this-&gt;load-&gt;view('blogview');
  87. &#125;
  88. &#125;
  89. ?&gt; </textarea></p>
  90. <p>如果你使用先前你用的 URL 浏览你的网站,你将会看到你的新视图. URL 与下面的类似:</p>
  91. <code>example.com/index.php/<var>blog</var>/</code>
  92. <h2>载入多个视图</h2>
  93. <p>CodeIgniter 能智能的处理多个从控制器发起的视图载入函数调用 $this-&gt;load-&gt;view。如果有多个调用,那么他们将会被合并到一起。例如,你可能希望有一个标题视图、一个菜单视图、一个内容视图、和一个页脚视图。他们看起来应该是这样:</p>
  94. <p><code>&lt;?php<br />
  95. <br />
  96. class Page extends CI_Controller &#123;<br /><br />
  97. &nbsp;&nbsp;&nbsp;function index()<br />
  98. &nbsp;&nbsp;&nbsp;&#123;<br />
  99. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$data['page_title'] = 'Your title';<br />
  100. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('header');<br />
  101. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('menu');<br />
  102. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('content', $data);<br />
  103. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('footer');<br />
  104. &nbsp;&nbsp;&nbsp;&#125;<br />
  105. <br />
  106. &#125;<br />
  107. ?&gt;</code></p>
  108. <p>在上面的例子中,我们使用了“动态添加数据”,你将在下面看到。</p>
  109. <h2>用子文件夹存储视图</h2>
  110. <p>如果你想让文件更有组织性,你也可以用子文件夹来存储你的视图文件.. 当你在载入视图时,必须加上子文件夹的名字. 示例如下:</p>
  111. <p><code>$this-&gt;load-&gt;view('<kbd>folder_name</kbd>/<var>file_name</var>');</code></p>
  112. <h2>给视图添加动态数据</h2>
  113. <p>数据通过控制器以一个<strong>数组</strong>或是<strong>对象</strong>的形式传入视图 , 这个数组或对象作为视图载入函数的第二个参数 .下面便是使用数组的示例:</p>
  114. <p><code>$data = array(<br />
  115. 'title' => 'My Title',<br />
  116. 'heading' => 'My Heading',<br />
  117. 'message' => 'My Message'<br />
  118. );<br />
  119. <br />
  120. $this-&gt;load-&gt;view('blogview', <var>$data</var>);</code></p>
  121. <p>这里是使用对象的示例:</p>
  122. <p><code>$data = new Someclass();<br />
  123. $this-&gt;load-&gt;view('blogview', <var>$data</var>);</code></p>
  124. <p>当我们一次性载入多个视图的时候,你只需在第一个视图传入数据就可以了(header视图显示title,content视图显示message),比如:</p>
  125. <p><code><br />
  126. &lt;?php<br />
  127. <br />
  128. class Page extends CI_Controller &#123;<br /><br />
  129. &nbsp;&nbsp;&nbsp;function index()<br />
  130. &nbsp;&nbsp;&nbsp;&#123;<br />
  131. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$data['title'] = 'Your title';<br />
  132. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$data['message'] = 'Your message';<br />
  133. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('header',$data);<br />
  134. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('content');<br />
  135. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('footer');<br />
  136. &nbsp;&nbsp;&nbsp;&#125;<br />
  137. <br />
  138. &#125;<br />
  139. ?&gt;</code></p>
  140. <p>注意:如果你使用一个对象,那么类变量将转换为数组元素。</p>
  141. <p>好了,让我们用你的控制器试试。打开控制器并添加以下代码:</p>
  142. <p><textarea cols="50" rows="14" style="width: 100%;" class="textarea">&lt;?php
  143. class Blog extends CI_Controller &#123;
  144. function index()
  145. &#123;
  146. $data['title'] = "My Real Title";
  147. $data['heading'] = "My Real Heading";
  148. $this-&gt;load-&gt;view('blogview', $data);
  149. &#125;
  150. &#125;
  151. ?&gt; </textarea></p>
  152. <p>现在,打开你的视图文件,将其中的文本替换成与数组对应的变量:</p>
  153. <p><textarea rows="10" cols="50" style="width: 100%;" class="textarea">
  154. &lt;html&gt;
  155. &lt;head&gt;
  156. &lt;title&gt;&lt;?php echo $title;?&gt;&lt;/title&gt;
  157. &lt;/head&gt;
  158. &lt;body&gt;
  159. <h1>&lt;?php echo $heading;?&gt;</h1>
  160. &lt;/body&gt;
  161. &lt;/html&gt;
  162. </textarea></p>
  163. <p>然后使用你先前用过的URL载入页面,你将看到变量已经被替换。</p>
  164. <h2>创建循环</h2>
  165. <p>你传入视图文件的数据,不仅仅局限于简单的变量。你可以传递多维数组。例如:你从数据库里面取出数据就是典型的多维数据。</p>
  166. <p>这里是个简单的示例。添加以下代码到你的控制器:</p>
  167. <p><textarea cols="50" rows="17" style="width: 100%;" class="textarea">&lt;?php
  168. class Blog extends CI_Controller &#123;
  169. function index()
  170. &#123;
  171. $data['todo_list'] = array('Clean House', 'Call Mom', 'Run Errands');
  172. $data['title'] = "My Real Title";
  173. $data['heading'] = "My Real Heading";
  174. $this-&gt;load-&gt;view('blogview', $data);
  175. &#125;
  176. &#125;
  177. ?&gt; </textarea></p>
  178. <p>现在打开你的视图文件,创建一个循环:</p>
  179. <textarea class="textarea" style="width:100%" cols="50" rows="24">
  180. &lt;html&gt;
  181. &lt;head&gt;
  182. &lt;title>&lt;?php echo $title;?&gt;&lt;/title>
  183. &lt;/head&gt;
  184. &lt;body&gt;
  185. &lt;h1>&lt;?php echo $heading;?&gt;&lt;/h1>
  186. <h3>My Todo List</h3>
  187. <ul>
  188. &lt;?php foreach ($todo_list as $item):?&gt;
  189. &lt;li>&lt;?php echo $item;?&gt;&lt;/li>
  190. &lt;?php endforeach;?&gt;
  191. </ul>
  192. &lt;/body&gt;
  193. &lt;/html&gt;
  194. </textarea>
  195. <p><strong>注意:</strong> 上面的例子中我们使用PHP替代语法。如果你对这种语法不熟悉,可以在<a href="alternative_php.html">这里</a>阅读。</p>
  196. <h2>获取视图内容</h2>
  197. <p>view函数第三个<strong>可选</strong>参数可以改变函数的行为,让数据作为字符串返回而不是发送到浏览器。如果想用其它方式对数据进一步处理,这样做很有用。如果将view第三个参数设置为<dbd>true</dbd>(布尔)则函数返回数据。view函数缺省行为是 <dbd>false</dbd>, 将数据发送到浏览器。如果想返回数据,记得将它赋到一个变量中:</p>
  198. <code>$string = $this-&gt;load-&gt;view('<var>myfile</var>', '', <kbd>true</kbd>);</code>
  199. <p>例子:有些情况下,你并不想直接输出视图,而是仅仅想得到视图的内容以备后用。那么可以参考如下代码。</p>
  200. <p><textarea cols="50" rows="13" style="width: 100%;" class="textarea">&lt;?php
  201. class Blog extends CI_Controller &#123;
  202. function index()
  203. &#123;
  204. $data['todo_list'] = array('Clean House', 'Call Mom', 'Run Errands');
  205. $data['title'] = "My Real Title";
  206. $data['heading'] = "My Real Heading";
  207. $buffer = $this-&gt;load-&gt;view('blogview', $data, true);
  208. &#125;
  209. &#125;
  210. ?&gt; </textarea></p>
  211. <p>view方法中的第三个参数表示不输出视图,而只是将结果返回给一个变量。</p><p>&nbsp;</p>
  212. <div id="Contributors">
  213. 翻译贡献者:
  214. 34333432, hewenxiang, Hex, ianyang, irini, lishen2, longjianghu, sydcurie, thankwsx, zhupeng</div>
  215. <div id="DocDate">
  216. 最后修改: 2012-02-05 23:43:50</div>
  217. </div>
  218. <!-- END CONTENT -->
  219. <div id="footer">
  220. <p>
  221. 上一个主题:&nbsp;&nbsp;<a href="reserved_names.html">保留字</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  222. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="models.html">模型</a> </p>
  223. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  224. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  225. </div>
  226. </body>
  227. </html>