Zend Framework教程-Autoloading使用方法
来源:互联网 发布:泰拳的杀伤力 知乎 编辑:程序博客网 时间:2024/05/09 19:52
通常,只需将需要引入包含类,然后实例化它即可。由于Zend_Loader_Autoloader采用的单例模式,可以使用getInstance()方法来获取一个实例。
require_once 'Zend/Loader/Autoloader.php';Zend_Loader_Autoloader::getInstance();
默认情况下,可以加载命名空间前缀为"Zend_"或 "ZendX_"的任何类,只要确保已经指定include_path。
如果想使用其他的命名空间前缀?最好的,最简单的方法是调用registerNamespace() 方法。您可以通过传递一个单一的命名空间前缀,或一个数组:
require_once 'Zend/Loader/Autoloader.php';$loader = Zend_Loader_Autoloader::getInstance();$loader->registerNamespace('Foo_');$loader->registerNamespace(array('Foo_', 'Bar_'));
或者,你可以把Zend_Loader_Autoloader作为一个“备用”自动加载器。这意味着如果命名空间无论是否定义,都会尝试自动加载。
$loader->setFallbackAutoloader(true);(注意:这种方式是不推荐的,尽量不要使用)。
Zend_Loader_Autoloader的内部实现是使用 Zend_Loader::loadClass() 加载类的。该方法的使用 include() 来尝试加载给定的类文件。 include()将返回一个布尔值,如果没有成功返回FALSE - 而且还发出PHP警告。 可能会导致以下问题:
如果启用了display_errors,警告将包含在输出中。
根据你所配置的error_reporting级别,它也可以输出到日志中。
可以禁止这些错误消息,具体如下:(但注意,display_errors启用时,错误日志将始终显示。)
$autoloader->suppressNotFoundWarnings(true);
选择一个Zend Framework的版本
ZendFramework/|-- 1.9.2/| |-- library/|-- ZendFramework-1.9.1-minimal/| |-- library/|-- 1.8.4PL1/| |-- library/|-- 1.8.4/| |-- library/|-- ZendFramework-1.8.3/| |-- library/|-- 1.7.8/| |-- library/|-- 1.7.7/| |-- library/|-- 1.7.6/| |-- library/
$autoloader->setZfPath($path, 'latest');
$autoloader->setZfPath($path, '1.8');
$autoloader->setZfPath($path, '1.7.7');
也可以使用配置文件
[production]autoloaderZfPath = "path/to/ZendFramework"autoloaderZfVersion = "1.7.7" [qa]autoloaderZfVersion = "1.8" [development]autoloaderZfVersion = "latest"
Autoloader接口
注:命名空间前缀和PHP命名空间
PHP5.3已经发布。该版本中,PHP现在已经正式支持命名空间。
然而,Zend Framework的命名空间和PHP 5.3的命名空间完全不同的。 Zend Framework中,提到的“命名空间”,是指一个类前缀。例如,所有的Zend Framework的类名称的前缀“Zend_”。 这是我们指定的“命名空间”。
在Zend Framework 2.0.0使用了原生的PHP命名空间。
自动加载器除了能够指定任意回调以外,Zend Framework还定义了一个需要自动加载类实现的接口Zend_Loader_Autoloader_Interface:
interface Zend_Loader_Autoloader_Interface{ public function autoload($class);}
如果您希望在Zend Framework中使用自定义的自动加载器,可以使用 Zend_Loader_Autoloader的 pushAutoloader()和unshiftAutoloader()方法。
通过这些方法将在Zend Framework的内部自动装载器之后追加或之前使用自定义的加载器。
每个方法接受一个可选的第二个参数,类的命名空间前缀。自动加载器只查找给定的类前缀。如果不是指定的类前缀,将跳过自动加载器 , 这可能是一种性能改进方式。
当使用这个接口时,你需要传递类实例到Zend_Loader_Autoloader类的pushAutoloader()和unshiftAutoloader()方法,具体如下:
// Append function 'my_autoloader' to the stack,// to manage classes with the prefix 'My_':$loader->pushAutoloader('my_autoloader', 'My_'); // Prepend static method Foo_Loader::autoload() to the stack,// to manage classes with the prefix 'Foo_':$loader->unshiftAutoloader(array('Foo_Loader', 'autoload'), 'Foo_');
// Assume Foo_Autoloader implements Zend_Loader_Autoloader_Interface:$foo = new Foo_Autoloader(); $autoloader->pushAutoloader($foo, 'Foo_');
Zend_Loader_Autoloader的相关方法
获取实例
resetInstance()void
N/A重置Zend_Loader_Autoloadersingleton实例的状态,恢复它的原始状态,注销所有的自动加载器回调和所有注册的命名空间。
string|FALSE
$class,required. A string class name to load.
试图加载一个类。
setDefaultAutoloader($callback)Zend_Loader_Autoloader$callback,required.
指定默认的加载器回调
getDefaultAutoloader()callback
N/A获取默认的加载器接口;默认是Zend_Loader::loadClass().
setAutoloaders(array $autoloaders)Zend_Loader_Autoloader$autoloaders,required.
设置在自动加载器栈使用具体的自动加载器列表。自动加载器列表中的每个项目必须是PHPcallback。
getNamespaceAutoloaders($namespace)Array
$namespace,required
获取所有已注册的自动加载器来加载一个特定的的命名空间。
$namespace,required.
注册命名空间. If$namespace is a string, it registers that namespace; if it's an array of strings, registers each as a namespace.
unregisterNamespace($namespace)Zend_Loader_Autoloader$namespace,required.
boolean|Zend_Loader_Autoloader
$flag,optional.
错误提示
setFallbackAutoloader($flag)Zend_Loader_Autoloader$flag,required.
isFallbackAutoloader()BooleanN/A
getClassAutoloaders($class)Array
$class,required.
unshiftAutoloader($callback, $namespace = '')Zend_Loader_Autoloader
$callback,required. A valid PHPcallback
$namespace,optional. A string representing a class prefix namespace.
pushAutoloader($callback, $namespace = '')Zend_Loader_Autoloader
$callback,required. A valid PHPcallback
$namespace,optional. A string representing a class prefix namespace.
removeAutoloader($callback, $namespace = '')Zend_Loader_Autoloader
$callback,required. A valid PHPcallback
$namespace,optional. A string representing a class prefix namespace, or an array of namespace strings.
- Zend Framework教程-Autoloading使用方法
- Zend Framework教程-Resource Autoloading使用方法
- Zend Framework教程-Autoloading介绍
- Zend Framework 中的autoloading使用
- Zend Framework教程-Application
- Zend Framework教程-Bootstrap
- Zend Framework教程-Resources
- Zend Framework教程-Zend_Controller
- Zend Framework教程-Zend_View
- Zend Framework 教程
- Zend Framework教程-Zend_Form
- Zend Framework教程-入门相关
- Zend Framework教程-application.ini
- Zend Framework教程-MVC-Controller
- Zend Framework教程-Zend_Controller_Plugin插件
- Zend Framework教程-ErrorController,Exception
- Zend Framework教程-入门相关
- Zend Framework教程-用Zend命令行快速创建Zend应用
- 答haoyuhai问 .
- jmeter的执行
- 2012 IT热门人才需求类型盘点
- PERL/UNIX/SHELL/LINUX/PROVER
- Python学习笔记(3)--文件读写
- Zend Framework教程-Autoloading使用方法
- FindWindow
- 数组遍历
- iPad企业销售将突破100亿美元,微软笑而不语
- SQLite日期类型
- 关于MFC项目中使用CDHtmlDialog禁止脚本错误的方法
- 豌豆荚年终盘点: 打折优惠搜索下载近6000万次
- 《今天你买到票了吗?——从铁道部12306.cn网站漫谈电子商务网站的“海量事务高速处理”系统》
- 黑马程序员——C#面向对象基础复习日记