core_classes.html 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  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/core_classes.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>每次CodeIgniter运行时都有很多基础类作为核心框架的一部分被自动初始化.但你也可以使用经过你修改的类来替换甚至扩展这些原始的核心系统类.</p>
  62. <p><strong>大多数用户一般不会有这种需求,但对于那些想较大幅度的改变CodeIgniter的人来说,我们依然提供了替换和扩展核心系统类的选择.</strong>
  63. </p>
  64. <p class="important"><strong>注意:</strong>&nbsp; 改变系统核心类会产生很大影响,所以在你做之前必须清楚地知道自己正在做什么.</p>
  65. <h2>系统类清单</h2>
  66. <p>以下是系统核心文件的清单,它们在每次CodeIgniter启动时被调用:</p>
  67. <ul>
  68. <li>Benchmark</li>
  69. <li>Config</li>
  70. <li>Controller</li>
  71. <li>Exceptions</li>
  72. <li>Hooks</li>
  73. <li>Input</li>
  74. <li>Language</li>
  75. <li>Loader</li>
  76. <li>Log</li>
  77. <li>Output</li>
  78. <li>Router</li>
  79. <li>URI</li>
  80. <li>Utf8</li>
  81. </ul>
  82. <h2>替换核心类</h2>
  83. <p>要使用你自己的系统类替换默认类只需简单的将你自己的 .php 文件放入本地文件夹 <dfn>application/core</dfn></p>
  84. <code>application/core/<dfn>some-class.php</dfn></code>
  85. <p>如果这个文件夹不存在你可以自己创建一个.</p>
  86. <p>只要你自定义的文件名与默认的完全一样,它就会自动替换原有的类.</p>
  87. <p>要注意的是你自定义的类必须以CI作为前缀,例如你自己建立了<kbd>Input.php</kbd>类的名字必须是:</p>
  88. <code>
  89. class CI_Input &#123;<br /><br />
  90. &#125;
  91. </code>
  92. <h2>扩展核心类</h2>
  93. <p>如果你需要在现有类库中加入一两个新的功能,那就完全不必要替换整个类库文件.你只需简单地扩展(继承)现有的类,扩展一个类就像在类中增加一些例外:</p>
  94. <ul>
  95. <li>扩展的类必须申明由父类扩展而来.</li>
  96. <li>新扩展的类所在的文件必须以 <kbd>MY_</kbd> 为前缀(这个选项是可配置的,下面有说明).</li>
  97. </ul>
  98. <p>例如,要扩展原有的<kbd>Input</kbd> 类,你应该新建一个文件名为<dfn>application/core/</dfn><kbd>MY_Input.php</kbd>, 并按如下声明你的类:</p>
  99. <code>
  100. class MY_Input extends CI_Input &#123;<br /><br />
  101. &#125;</code>
  102. <p>注意:如果你需要在类中使用构造函数,你必须在构造函数中显式继承父类构造函数:</p>
  103. <code>
  104. class MY_Input extends CI_Input &#123;<br />
  105. <br />
  106. &nbsp;&nbsp;&nbsp;&nbsp;function __construct()<br />
  107. &nbsp;&nbsp;&nbsp;&nbsp;&#123;<br />
  108. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct();<br />
  109. &nbsp;&nbsp;&nbsp;&nbsp;&#125;<br />
  110. &#125;</code>
  111. <p class="important"><strong>Tip:</strong>&nbsp; 所有在你的新类中定义的函数如果与父类中函数的命名完全一样,这些函数就能取代父类中原有的函数
  112. (这也被称为"方法覆盖").这允许你在本质上改变CodeIgniter的核心.</p>
  113. <p>如果你扩展了控制器核心类,那么也要在你的应用程序控制器的构造函数中使用这个新类。</p>
  114. <code>class Welcome extends MY_Controller &#123;<br />
  115. <br />
  116. &nbsp;&nbsp;&nbsp;&nbsp;function __construct()<br />
  117. &nbsp;&nbsp;&nbsp;&nbsp;&#123;<br />
  118. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct();<br />
  119. &nbsp;&nbsp;&nbsp;&nbsp;&#125;<br />
  120. <br />
  121. &nbsp;&nbsp;&nbsp;&nbsp;function index()<br />
  122. &nbsp;&nbsp;&nbsp;&nbsp;&#123;<br />
  123. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;load-&gt;view('welcome_message');<br />
  124. &nbsp;&nbsp;&nbsp;&nbsp;&#125;<br />
  125. &#125;</code>
  126. <h3>自定义前缀</h3>
  127. <p>要设定你自己的子类前缀,请打开<dfn>application/config/config.php</dfn> 文件并找到这一项:</p>
  128. <code>$config['subclass_prefix'] = 'MY_';</code>
  129. <p>请注意所有原始CodeIgniter类库以 <kbd>CI_</kbd> 作为前缀,所以请勿以CI_作为你自己的前缀.<b>所有的扩展核心类必须放到core目录中!</b></p><p>&nbsp;</p>
  130. <div id="Contributors">
  131. 翻译贡献者:
  132. dustin, Hex, longbill, qixingyue, skey, thinksand</div>
  133. <div id="DocDate">
  134. 最后修改: 2014-02-14 14:54:29</div>
  135. </div>
  136. <!-- END CONTENT -->
  137. <div id="footer">
  138. <p>
  139. 上一个主题:&nbsp;&nbsp;<a href="creating_libraries.html">创建你自己的程序库</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  140. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="hooks.html">钩子 - 扩展核心</a> </p>
  141. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  142. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  143. </div>
  144. </body>
  145. </html>