Zend Framework教程之Autoloading用法詳解
本文實例講述了Zend Framework教程之Autoloading用法。分享給大家供大家參考,具體如下:
一、概述
自動加載是一種機制,無需依賴手動編寫PHP代碼。參考»PHP手冊自動加載,一旦自動加載器被定義,你試圖使用一個沒有定義的類或接口的情況下,它會自動被調(diào)用。
使用自動加載,在項目中你不必擔心類的存放位置。定義一個良好定義的自動加載器,您不需要考慮一個類文件相對于當前類文件的位置,您只需使用類,自動加載器將自動查找文件。
此外,自動加載,確保只加載一次,提升了性能 -所以可以用它替代require_once()。
Zend Framework 鼓勵使用自動加載,并提供了許多工具實現(xiàn)自動加載代碼庫以及應(yīng)用程序代碼。下面將介紹這些工具,以及如何有效地使用它們。
自動加載的實現(xiàn)約定
類命名約定
Zend Framework借鑒了 PEAR的想法,即類名與文件系統(tǒng)的1:1的關(guān)系。簡單地說,下劃線字符("_")替換目錄分隔,以代表該文件的路徑,然后添加后綴“.php”。例如,類“Foo_Bar_Baz”將對應(yīng)文件系統(tǒng)上的"Foo/Bar/Baz.php"。假設(shè)已通過PHP的include_path設(shè)置類的位置,這使得可以通過 include() 和 require()找到相對include_path中設(shè)置的路徑查找文件名。
此外,推薦使用供應(yīng)商名稱或項目名稱作為前綴。這意味著,你寫的所有的類都有一個共同的類前綴,例如,Zend Framework的所有代碼前綴為“Zend_”。這種命名約定有助于防止命名沖突。在ZendFramework中,我們經(jīng)常提到“namespace”前綴,要注意不要把它與PHP的本地命名空間混淆。
自動加載器設(shè)計約定
Zend Framework通過Zend_Loader_Autoloader實現(xiàn)支持自動加載的,主要提供有以下目標和設(shè)計元素:
提供命名空間匹配。如果類的命名空間前綴是沒有注冊的命名空間,會返回FALSE。
允許定義自動加載器作為一個備用的自動加載器。一個團隊可能分布廣泛,或使用一個為定義的命名空間前綴情況下,它會嘗試匹配任何命名空間前綴。但是,這種做法是不推薦,因為它可能會導致不必要的查找。
允許開啟禁止錯誤提示。 因此,默認情況下,它應(yīng)該處于關(guān)閉狀態(tài)。開發(fā)階段,可以啟用它。
可以自定義自動加載。一些開發(fā)商不希望使用Zend_Loader::loadClass()自動加載,但仍想使用Zend Framework的自動加載機制。 Zend_Loader_Autoloader允許使用自定義的自動加載。
允許使用SPL自動加載回調(diào)鏈。這樣做的目的是允許指定額外的自動加載器 。
二、用法:
通常,只需將需要引入包含類,然后實例化它即可。由于Zend_Loader_Autoloader采用的單例模式,可以使用getInstance()方法來獲取一個實例。
require_once 'Zend/Loader/Autoloader.php'; Zend_Loader_Autoloader::getInstance();
默認情況下,可以加載命名空間前綴為"Zend_"或 "ZendX_"的任何類,只要確保已經(jīng)指定include_path。
如果想使用其他的命名空間前綴?最好的,最簡單的方法是調(diào)用registerNamespace() 方法。您可以通過傳遞一個單一的命名空間前綴,或一個數(shù)組:
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的內(nèi)部實現(xiàn)是使用 Zend_Loader::loadClass() 加載類的。該方法的使用 include() 來嘗試加載給定的類文件。 include()將返回一個布爾值,如果沒有成功返回FALSE - 而且還發(fā)出PHP警告。 可能會導致以下問題:
如果啟用了display_errors,警告將包含在輸出中。
根據(jù)你所配置的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已經(jīng)發(fā)布。該版本中,PHP現(xiàn)在已經(jīng)正式支持命名空間。
然而,Zend Framework的命名空間和PHP 5.3的命名空間完全不同的。 Zend Framework中,提到的“命名空間”,是指一個類前綴。例如,所有的Zend Framework的類名稱的前綴“Zend_”。 這是我們指定的“命名空間”。
在Zend Framework 2.0.0使用了原生的PHP命名空間。
自動加載器除了能夠指定任意回調(diào)以外,Zend Framework還定義了一個需要自動加載類實現(xiàn)的接口Zend_Loader_Autoloader_Interface:
interface Zend_Loader_Autoloader_Interface { public function autoload($class); }
如果您希望在Zend Framework中使用自定義的自動加載器,可以使用 Zend_Loader_Autoloader的 pushAutoloader()和unshiftAutoloader()方法。
通過這些方法將在Zend Framework的內(nèi)部自動裝載器之后追加或之前使用自定義的加載器。
每個方法接受一個可選的第二個參數(shù),類的命名空間前綴。自動加載器只查找給定的類前綴。如果不是指定的類前綴,將跳過自動加載器 , 這可能是一種性能改進方式。
當使用這個接口時,你需要傳遞類實例到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的相關(guān)方法
Method | Return Value | Parameters | Description |
---|---|---|---|
getInstance() | Zend_Loader_Autoloader | N/A |
獲取實例 |
resetInstance() | void |
N/A |
重置Zend_Loader_Autoloadersingleton實例的狀態(tài),恢復它的原始狀態(tài),注銷所有的自動加載器回調(diào)和所有注冊的命名空間。 |
autoload($class) | string|FALSE |
|
試圖加載一個類。 |
setDefaultAutoloader($callback) | Zend_Loader_Autoloader |
|
指定默認的加載器回調(diào) |
getDefaultAutoloader() | callback |
N/A |
獲取默認的加載器接口;默認是Zend_Loader::loadClass(). |
setAutoloaders(array $autoloaders) | Zend_Loader_Autoloader |
|
設(shè)置在自動加載器棧使用具體的自動加載器列表。自動加載器列表中的每個項目必須是PHPcallback。 |
getAutoloaders() | Array | N/A |
|
getNamespaceAutoloaders($namespace) | Array |
|
獲取所有已注冊的自動加載器來加載一個特定的的命名空間。 |
registerNamespace($namespace) | Zend_Loader_Autoloader |
|
注冊命名空間. 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 |
|
|
getRegisteredNamespaces() | Array | N/A |
|
suppressNotFoundWarnings($flag = null) | boolean|Zend_Loader_Autoloader |
|
錯誤提示 |
setFallbackAutoloader($flag) | Zend_Loader_Autoloader |
|
|
isFallbackAutoloader() | Boolean | N/A |
|
getClassAutoloaders($class) | Array |
|
|
unshiftAutoloader($callback, $namespace = '') | Zend_Loader_Autoloader |
|
|
pushAutoloader($callback, $namespace = '') | Zend_Loader_Autoloader |
|
|
removeAutoloader($callback, $namespace = '') | Zend_Loader_Autoloader |
|
更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《Yii框架入門及常用技巧總結(jié)》、《ThinkPHP入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
- windows下zendframework項目環(huán)境搭建(通過命令行配置)
- Zend Framework教程之配置文件application.ini解析
- zend framework配置操作數(shù)據(jù)庫實例分析
- WINDOWS + WAMP + Zend Framework 配置步驟分享
- iis7配置zend framework的地址重寫規(guī)則[url_rewrite]
- zend framework多模塊多布局配置
- Zend Framework教程之連接數(shù)據(jù)庫并執(zhí)行增刪查的方法(附demo源碼下載)
- Zend Framework入門知識點小結(jié)
- Zend Framework基本頁面布局分析
- Zend Framework連接Mysql數(shù)據(jù)庫實例分析
- Zend Framework+smarty用法實例詳解
- Zend Framework教程之Bootstrap類用法概述
- Zend Framework入門之環(huán)境配置及第一個Hello World示例(附demo源碼下載)
相關(guān)文章
詳解PHP中cookie和session的區(qū)別及cookie和session用法小結(jié)
這篇文章主要介紹了PHP中cookie和session的區(qū)別及cookie和session用法小結(jié)的相關(guān)資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-06-06PHP+jQuery+Ajax實現(xiàn)用戶登錄與退出
本文使用Ajax無刷新登錄和退出,從而提升了用戶體驗。 若用戶為登錄狀態(tài),則顯示用戶相關(guān)登錄信息,否則顯示登錄表單。2015-04-04ubutu 16.04環(huán)境下,PHP與mysql數(shù)據(jù)庫,網(wǎng)頁登錄驗證實例講解
下面小編就為大家?guī)硪黄猽butu 16.04環(huán)境下,PHP與mysql數(shù)據(jù)庫,網(wǎng)頁登錄驗證實例講解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07thinkPHP實現(xiàn)將excel導入到數(shù)據(jù)庫中的方法
這篇文章主要介紹了thinkPHP實現(xiàn)將excel導入到數(shù)據(jù)庫中的方法,涉及thinkPHP結(jié)合PHPExcel插件操作excel與數(shù)據(jù)庫的相關(guān)技巧,需要的朋友可以參考下2016-04-04