output.html 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  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/libraries/output.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>输出类是只有一个主要功能的简单的类: 发送最终的Web页面到所请求的浏览器。如果您开启<a href="../general/caching.html">缓存</a>功能,他还负责缓存您的网页文件。</p>
  62. <p>输出类虽然很简单,但是它实现的功能却很重要咯: 输出最后的执行结果给发送请示的浏览器. 如果你选择了使用<a href="../general/caching.html">缓存</a> ,这块也归它管.</p>
  63. <p class="important"><strong>注意:</strong>输出类的初始化操作是由系统自动完成的,基本上不用你操心.</p>
  64. <p>在一般的情况下你是感觉不到它的存在的(也用不着去关心),对于你来说它就是透明的,不用去干预,它就能正常的工作.
  65. 比如说, 你使用<a href="loader.html">装载器类</a>加载了一个视图文件, 这个视图文件的内容会自动传递给输出类对象, 然后呢,在方法执行完毕后会自动调用输出类对象将执行的结果输出.
  66. 但是呢,实际开发的过程当中会遇见一些特殊的情况需要我们干预输出,接管输出的控制权(像是客户要求将数据导出成Excel,提供下载),这种时候,下面的这些个方法就用啦:</p>
  67. <h2>$this-&gt;output-&gt;set_output();</h2>
  68. <p>告诉CodeIgniter方法执行完毕后,用给定的数据做为输出。例如:</p>
  69. <code>$this-&gt;output-&gt;set_output($data);</code>
  70. <p><strong>重要:</strong>使用这个方法有一点很重要,就要将它放在最后一句,千万要注意啊,到时候出了错,不要怪我没提醒你.</p>
  71. <h2>$this-&gt;output-&gt;set_content_type();</h2>
  72. <p>允许你设置页面的mime类型以便于输出 JSON , JPEG, XML 等类型的数据.</p>
  73. <code>$this-&gt;output<br/>
  74. &nbsp;&nbsp;&nbsp;&nbsp;-&gt;set_content_type('application/json')<br/>
  75. &nbsp;&nbsp;&nbsp;&nbsp;-&gt;set_output(json_encode(array('foo' => 'bar')));<br/>
  76. <br/>
  77. $this-&gt;output<br/>
  78. &nbsp;&nbsp;&nbsp;&nbsp;-&gt;set_content_type('jpeg') // 你也可以用".jpeg",它在查找 config/mimes.php 文件之前会移除句号<br/>
  79. &nbsp;&nbsp;&nbsp;&nbsp;-&gt;set_output(file_get_contents&#40;'files/something.jpg'&#41;);</code>
  80. <p><strong>重要:</strong> 确保你传递到此方法的非mime字符串在 config/mimes.php 存在,否则设置不起作用。</p>
  81. <h2>$this-&gt;output-&gt;get_output();</h2>
  82. <p>使用这个方法,你可以得到将要输出的数据,并把它保存起来,留着它用(我们做新闻类型网站的时候,常常需要生成静态的HTML文件). 例如:</p>
  83. <code>$string = $this-&gt;output-&gt;get_output();</code>
  84. <p>注意,如果先前的数据已经被一个类似 <var>$this-&gt;load-&gt;view()</var> 的 CodeIgniter 函数送到了输出类,那么只能取得那个函数之后的输出。</p>
  85. <h2>$this-&gt;output-&gt;append_output();</h2>
  86. <p>在输出字符串后附加数据。例如:</p>
  87. <code>$this-&gt;output-&gt;append_output($data);</code>
  88. <h2>$this-&gt;output-&gt;set_header();</h2>
  89. <p>使用此方法,允许你设置将会被发送到浏览器的HTTP协议的标头,作用相当于php的标准函数: header()。例如:</p>
  90. <code>
  91. $this-&gt;output-&gt;set_header("HTTP/1.0 200 OK");<br />
  92. $this-&gt;output-&gt;set_header("HTTP/1.1 200 OK");<br />
  93. $this-&gt;output-&gt;set_header('Last-Modified: '.gmdate('D, d M Y H:i:s', $last_update).' GMT');<br />
  94. $this-&gt;output-&gt;set_header("Cache-Control: no-store, no-cache, must-revalidate");<br />
  95. $this-&gt;output-&gt;set_header("Cache-Control: post-check=0, pre-check=0");<br />
  96. $this-&gt;output-&gt;set_header("Pragma: no-cache"); </code>
  97. <h2>$this-&gt;output-&gt;set_status_header(<var>code</var>, '<var>text</var>');</h2>
  98. <p>允许你手动设置服务器状态头(header)。例如:</p>
  99. <code>$this-&gt;output-&gt;set_status_header('401');<br />
  100. // 将header设置为: Unauthorized</code>
  101. <p><a href="#">单击这里</a>查看全部的 header 列表。</p>
  102. <h2>$this-&gt;output-&gt;enable_profiler();</h2>
  103. <p>允许你开启或禁用<a href="../general/profiling.html">评测器</a>,评测器将在页的底部显示测试基准点或调试、优化需要的其他数据。</p>
  104. <p>在<a href="../general/controllers.html">控制器</a>函数的任何位置放置以下函数,可以开启评测器:</p>
  105. <code>$this-&gt;output-&gt;enable_profiler(TRUE);</code>
  106. <p>当开启评测器功能,会在您的页面底部生成一个报告。</p>
  107. <p>你可以用以下语句禁用评测器:</p>
  108. <code>$this-&gt;output-&gt;enable_profiler(FALSE);</code>
  109. <h2>$this-&gt;output-&gt;set_profiler_sections();</h2>
  110. <p>允许你在评测器启用时控制(开/关)其特定部分。请参考<a href="../general/profiling.html">评测器</a>了解详细信息。</p>
  111. <h2>$this-&gt;output-&gt;cache();</h2>
  112. <p>CodeIgniter的输出类同样也控制缓存。要获取更多信息,请阅读 <a href="../general/caching.html">缓存文档</a>.</p>
  113. <h2>Parsing Execution Variables</h2>
  114. <p>默认情况下,CodeIgniter总会在输出中解析伪变量<var>&#123;elapsed_time&#125;</var>和<var>&#123;memory_usage&#125;</var>。 如需禁用,在控制器中将类属性<var>$parse_exec_vars</var>设为<var>FALSE</var>。
  115. <code>$this-&gt;output-&gt;parse_exec_vars = FALSE;</code>
  116. <p class="important">译者注:此处存在源码级错误,直接应用此代码会报错“Fatal error: Cannot access protected property CI_Output::$parse_exec_vars ”。建议用以下代码:
  117. <code>public $parse_exec_vars = TRUE;</code>
  118. 替换掉源文件systerm/core/Output.php第86行(CI版本2.1.3)的此句代码:
  119. <code>protected $parse_exec_vars = TRUE;</code>
  120. </p><p>&nbsp;</p>
  121. <div id="Contributors">
  122. 翻译贡献者:
  123. billycui, crazyfriday, csfhc, Glen, Hex, hk_yuhe, lishen2, Raidal, xwjie, yinzhili</div>
  124. <div id="DocDate">
  125. 最后修改: 2013-11-22 20:12:23</div>
  126. </div>
  127. <!-- END CONTENT -->
  128. <div id="footer">
  129. <p>
  130. 上一个主题:&nbsp;&nbsp;<a href="language.html">语言类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  131. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="pagination.html">分页类</a> </p>
  132. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  133. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  134. </div>
  135. </body>
  136. </html>