中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Zend Framework中Autoloading如何使用

發布時間:2021-06-23 15:34:17 來源:億速云 閱讀:121 作者:Leah 欄目:開發技術

本篇文章給大家分享的是有關Zend Framework中Autoloading如何使用,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

一、概述

自動加載是一種機制,無需依賴手動編寫PHP代碼。參考»PHP手冊自動加載,一旦自動加載器被定義,你試圖使用一個沒有定義的類或接口的情況下,它會自動被調用。

使用自動加載,在項目中你不必擔心類的存放位置。定義一個良好定義的自動加載器,您不需要考慮一個類文件相對于當前類文件的位置,您只需使用類,自動加載器將自動查找文件。

此外,自動加載,確保只加載一次,提升了性能 -所以可以用它替代require_once()。

Zend Framework 鼓勵使用自動加載,并提供了許多工具實現自動加載代碼庫以及應用程序代碼。下面將介紹這些工具,以及如何有效地使用它們。

自動加載的實現約定

類命名約定

Zend Framework借鑒了 PEAR的想法,即類名與文件系統的1:1的關系。簡單地說,下劃線字符("_")替換目錄分隔,以代表該文件的路徑,然后添加后綴“.php”。例如,類“Foo_Bar_Baz”將對應文件系統上的"Foo/Bar/Baz.php"。假設已通過PHP的include_path設置類的位置,這使得可以通過 include() 和 require()找到相對include_path中設置的路徑查找文件名。

此外,推薦使用供應商名稱或項目名稱作為前綴。這意味著,你寫的所有的類都有一個共同的類前綴,例如,Zend Framework的所有代碼前綴為“Zend_”。這種命名約定有助于防止命名沖突。在ZendFramework中,我們經常提到“namespace”前綴,要注意不要把它與PHP的本地命名空間混淆。

自動加載器設計約定

Zend Framework通過Zend_Loader_Autoloader實現支持自動加載的,主要提供有以下目標和設計元素:

提供命名空間匹配。如果類的命名空間前綴是沒有注冊的命名空間,會返回FALSE。

允許定義自動加載器作為一個備用的自動加載器。一個團隊可能分布廣泛,或使用一個為定義的命名空間前綴情況下,它會嘗試匹配任何命名空間前綴。但是,這種做法是不推薦,因為它可能會導致不必要的查找。
允許開啟禁止錯誤提示。 因此,默認情況下,它應該處于關閉狀態。開發階段,可以啟用它。

可以自定義自動加載。一些開發商不希望使用Zend_Loader::loadClass()自動加載,但仍想使用Zend Framework的自動加載機制。 Zend_Loader_Autoloader允許使用自定義的自動加載。

允許使用SPL自動加載回調鏈。這樣做的目的是允許指定額外的自動加載器 。

二、用法:

通常,只需將需要引入包含類,然后實例化它即可。由于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的相關方法

MethodReturn ValueParametersDescription
getInstance()Zend_Loader_AutoloaderN/A

獲取實例

resetInstance()voidN/A

重置Zend_Loader_Autoloadersingleton實例的狀態,恢復它的原始狀態,注銷所有的自動加載器回調和所有注冊的命名空間。
 

autoload($class)string|FALSE
  • $class,required. A string class name to load.

試圖加載一個類。

setDefaultAutoloader($callback)Zend_Loader_Autoloader
  • $callback,required.

指定默認的加載器回調

getDefaultAutoloader()callbackN/A

獲取默認的加載器接口;默認是Zend_Loader::loadClass().

setAutoloaders(array $autoloaders)Zend_Loader_Autoloader
  • $autoloaders,required.

設置在自動加載器棧使用具體的自動加載器列表。自動加載器列表中的每個項目必須是PHPcallback。
 

getAutoloaders()ArrayN/A

 

getNamespaceAutoloaders($namespace)Array
  • $namespace,required

獲取所有已注冊的自動加載器來加載一個特定的的命名空間。
 

registerNamespace($namespace)Zend_Loader_Autoloader
  • $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.


 

getRegisteredNamespaces()ArrayN/A


 

suppressNotFoundWarnings($flag = null)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如何使用,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

怀宁县| 安乡县| 巨野县| 隆德县| 绩溪县| 武乡县| 丽江市| 永丰县| 普宁市| 芮城县| 浠水县| 衡水市| 郎溪县| 永寿县| 临漳县| 嘉鱼县| 郧西县| 昌都县| 通渭县| 晋州市| 琼中| 苗栗县| 乌兰浩特市| 香港| 交口县| 澜沧| 延川县| 琼结县| 北流市| 常宁市| 苏尼特左旗| 寻乌县| 昌黎县| 花垣县| 澎湖县| 文昌市| 塘沽区| 贺州市| 广西| 英德市| 邢台市|