辅助函数

辅助函数,顾名思义,是帮助我们完成特定任务的函数。每个辅助函数文件都是某一类函数的集合。例如, URL 辅助函数 帮助我们创建链接,表单辅助函数帮助我们创建表单元素,本文辅助函数 帮助我们处理文本的格式化,Cookie 辅助函数帮助我们读取或设置 Cookie ,文件辅助函数 帮助我们处理文件,等等等等。

不同于 CodeIgniter 中的大多数系统,辅助函数没有使用面向对象的方式来实现的。它们是简单的过程式函数,每个函数处理一个特定的任务,不依赖于其他的函数。

CodeIgniter 默认不会自己加载辅助函数,所以使用辅助函数的第一步就是加载它。一旦加载了,它就可以在你的 控制器视图 中全局访问了。

一般情况下,辅助函数位于 system/helpers 或者 application/helpers 目录目录下。CodeIgniter 首先会查找 application/helpers 目录,如果该目录不存在,或者你加载的辅助函数没有在该目录下找到,CodeIgniter 就会去 system/helpers/ 目录查找。

加载辅助函数

可以使用下面的方法简单的加载辅助函数:

  1. $this->load->helper('name');

name 参数为辅助函数的文件名,去掉 .php 文件后缀以及 _helper 部分。

例如,要加载 URL 辅助函数 ,它的文件名为 url_helper.php ,你可以这样加载它:

  1. $this->load->helper('url');

辅助函数可以在你的控制器方法的任何地方加载(甚至可以在你的视图文件中加载,尽管这不是个好的实践),只要确保在使用之前加载它就可以了。你可以在你的控制器的构造函数中加载它,这样就可以在该控制器的任何方法中使用它,你也可以在某个需要它的函数中单独加载它。

注解

上面的加载辅助函数的方法没有返回值,所以不要将它赋值给变量,直接调用就好了。

加载多个辅助函数

如果你需要加载多个辅助函数,你可以使用一个数组,像下面这样:

  1. $this->load->helper(
  2. array('helper1', 'helper2', 'helper3')
  3. );

自动加载辅助函数

如果你需要在你的整个应用程序中使用某个辅助函数,你可以将其设置为在 CodeIgniter 初始化时自动加载它。打开 application/config/autoload.php 文件然后将你想加载的辅助函数添加到autoload 数组中。

使用辅助函数

一旦你想要使用的辅助函数被加载,你就可以像使用标准的 PHP 函数一样使用它们。

例如,要在你的视图文件中使用 anchor() 函数创建一个链接,你可以这样做:

  1. <?php echo anchor('blog/comments', 'Click Here');?>

其中,"Click Here" 是链接的名称,"blog/comments" 是你希望链接到controller/method 的 URI 。

扩展辅助函数

为了扩展辅助函数,你需要在 application/helpers/ 目录下新建一个文件,文件名和已存在的辅助函数文件名一样,但是要加上 MY_ 前缀(这个可以配置,见下文)。

如果你只是想往现有类中添加一些功能,例如增加一两个方法,或者修改辅助函数中的某个函数,这时替换整个类感觉就有点杀鸡用牛刀了。在这种情况下,最好的方法是扩展类。

注解

“扩展”一词在这里可能不是很恰当,因为辅助函数函数都是过程式的独立函数,在传统编程中并不能被扩展。不过在 CodeIgniter 中,你可以向辅助函数中添加函数,或者使用你自己的函数替代辅助函数中的函数。

例如,要扩展原始的 数组辅助函数 ,首先你要创建一个文件 application/helpers/MY_array_helper.php ,然后像下面这样添加或重写函数:

  1. // any_in_array() is not in the Array Helper, so it defines a new function
  2. function any_in_array($needle, $haystack)
  3. {
  4. $needle = is_array($needle) ? $needle : array($needle);
  5.  
  6. foreach ($needle as $item)
  7. {
  8. if (in_array($item, $haystack))
  9. {
  10. return TRUE;
  11. }
  12. }
  13.  
  14. return FALSE;
  15. }
  16.  
  17. // random_element() is included in Array Helper, so it overrides the native function
  18. function random_element($array)
  19. {
  20. shuffle($array);
  21. return array_pop($array);
  22. }

设置自定义前缀

用于扩展辅助函数的文件名前缀和扩展类库和核心类是一样的。要自定义这个前缀,你可以打开application/config/config.php 文件然后找到这项:

  1. $config['subclass_prefix'] = 'MY_';

请注意所有原始的 CodeIgniter 类库都以 CI_ 开头,所以请不要使用这个作为你的自定义前缀。

然后?

在目录里你可以找到所有的辅助函数清单,你可以浏览下它们看看它们都是做什么的。