Zend Framework教程之Bootstrap類用法概述
本文實例講述了Zend Framework中Bootstrap類用法。分享給大家供大家參考,具體如下:
Zend_Application_Bootstrap_Bootstrapper
Zend_Application_Bootstrap_Bootstrapper是所有引導(dǎo)類必須實現(xiàn)的基本接口?;竟δ苁怯糜谂渲?,注冊資源,引導(dǎo)(無論是單個資源或整個應(yīng)用程序),并運行應(yīng)用程序。
接口方法:
Zend_Application_Bootstrap_Bootstrapper Interface
Method | Return Value | Parameters | Description |
---|---|---|---|
__construct( $application ) |
Void |
|
構(gòu)造方法。接受一個參數(shù),參數(shù)要求是一個Zend_Application對象,或另一個引導(dǎo)對象。 |
setOptions( array $options) |
Zend_Application_Bootstrap_Bootstrapper |
|
通常情況下, 選項都可以匹配映射到對應(yīng)的setter;否則,選項僅僅會被存儲,便于以后查找 |
getApplication() | Zend_Application |Zend_Application_Bootstrap_Bootstrapper | N/A |
獲取application實例 |
getEnvironment() | String | N/A |
獲取environment |
getClassResources() | Array | N/A |
獲取可以可用的資源 |
bootstrap($resource = null) | Mixed |
|
如果 $resource為空,注冊所有資源.如果為字符串注冊指定的資源;如果是數(shù)組, 只注冊指定的資源. |
run() | Void | N/A |
執(zhí)行引導(dǎo). |
Zend_Application_Bootstrap_ResourceBootstrapper
Zend_Application_Bootstrap_ResourceBootstrapper是一個接口,用于引導(dǎo)類加載注冊外部資源 。 也就是說,一個或多個資源不會直接在類中定義,而是通過插件形式引入。它應(yīng)該與Zend_Application_Bootstrap_Bootstrapper結(jié)合使用; Zend_Application_Bootstrap_BootstrapAbstract實現(xiàn)了這個功能。
接口方法:
Zend_Application_Bootstrap_ResourceBootstrapper Interface
Method | Return Value | Parameters | Description |
---|---|---|---|
registerPluginResource($resource, $options = null) | Zend_Application_Bootstrap_ResourceBootstrapper |
|
用于注冊資源類,通過可選選項傳遞資源 |
unregisterPluginResource($resource) | Zend_Application_Bootstrap_ResourceBootstrapper |
|
刪除插件資源 |
hasPluginResource($resource) | Boolean |
|
|
getPluginResource($resource) | Zend_Application_Resource_Resource |
|
|
getPluginResourceNames() | Array | N/A |
|
setPluginLoader(Zend_Loader_PluginLoader_Interface $loader) | Zend_Application_Bootstrap_ResourceBootstrapper |
|
|
getPluginLoader() | Zend_Loader_PluginLoader_Interface | N/A |
|
Zend_Application_Bootstrap_BootstrapAbstract
Zend_Application_Bootstrap_BootstrapAbstract是一個抽象類,它提供了一個通用的引導(dǎo)基本功能。它實現(xiàn)了Zend_Application_Bootstrap_Bootstrapper和Zend_Application_Bootstrap_ResourceBootstrapper。
Zend_Application_Bootstrap_BootstrapAbstract Methods
Method | Return Value | Parameters | Description |
---|---|---|---|
__construct($application) | Void |
|
Accepts either a Zend_Application or a Zend_Application_Bootstrap_Bootstrapper object as the sole argument. |
setOptions(array $options) | Zend_Application_Bootstrap_Bootstrapper |
|
所有選項都可以映射到選項指定的setter, 否則,該選項將只是被存儲供以后查找 例如,如果在擴展類中定義一個setFoo() 方法,可以通過foo選項傳遞值 |
getOptions() | Array | N/A |
|
hasOption($key) | Boolean |
|
|
getOption($key) | Mixed |
|
不存在返回 NULL |
setApplication(Zend_Application | Zend_Application_Bootstrap_Bootstrapper $application) | Zend_Application_Bootstrap_BootstrapAbstract |
|
|
getApplication() | Zend_Application |Zend_Application_Bootstrap_Bootstrapper | N/A |
|
getEnvironment() | String | N/A |
|
getClassResources() | Array | N/A |
|
getContainer() | Object | N/A |
獲取存儲資源的容器。如果沒有容器,可以通過Zend_Registry注冊,然后返回一個Zend_Registry實例。 |
setContainer($container) | Zend_Application_Bootstrap_BootstrapAbstract |
|
|
hasResource($name) | Boolean |
|
|
getResource($name) | Mixed |
|
|
bootstrap($resource = null) | Mixed |
|
如果 $resource為空,注冊所有資源.如果為字符串注冊指定的資源;如果是數(shù)組, 只注冊指定的資源. |
run() | Void | N/A |
|
__call($method, $args) | Mixed |
|
為了方便可以用'bootstrap<ResourceName>()'代替 bootstrap() 引導(dǎo)注冊資源。 |
Zend_Application_Bootstrap_Bootstrap
Zend_Application_Bootstrap_Bootstrap是Zend_Application_Bootstrap_BootstrapAbstract具體實現(xiàn)。它的主要功能是,注冊資源,然后運行 run() 方法。
在大多數(shù)情況下,你可以根據(jù)自己的引導(dǎo)需求繼承這個類或直接使用這個類,并來注冊資源插件。
啟用 Application 自動加載功能
此外,該引導(dǎo)的實現(xiàn)提供了自動加載指定“命名空間”或指定資源類的前綴的功能
本質(zhì)上,它實例化一個Zend_Application_Module_Autoloader的對象,參數(shù)為命名空間和引導(dǎo)類的目錄??梢蚤_啟這個功能,通過 “appnamespace”配置選項設(shè)置命名空間。
As an INI example:
appnamespace = "Application"
Or in XML:
<appnamespace>Application</appnamespace>
默認(rèn)情況下,Zend_Tool提供“Application”命名空間。
或者,可以在bootstrap類中通過$_appNamespace屬性指定命名空間。
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap { protected $_appNamespace = 'Application'; }
更多關(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è)計有所幫助。
相關(guān)文章
thinkPHP實現(xiàn)的聯(lián)動菜單功能詳解
這篇文章主要介紹了thinkPHP實現(xiàn)的聯(lián)動菜單功能,結(jié)合實例形式分析了thinkPHP聯(lián)動菜單的實現(xiàn)步驟與具體操作技巧,需要的朋友可以參考下2017-05-05PHP結(jié)合Jquery和ajax實現(xiàn)瀑布流特效
php+ajax+jquery實現(xiàn)無限瀑布流布局 寬度是一定的高度不定的瀑布流布局 也可以說是無縫拼圖 當(dāng)瀏覽器滾動到底部時候自動加載圖片,非常的實用,需要的小伙伴可以參考下。2016-01-01ThinkPHP5.1框架數(shù)據(jù)庫鏈接和增刪改查操作示例
這篇文章主要介紹了ThinkPHP5.1框架數(shù)據(jù)庫鏈接和增刪改查操作,結(jié)合實例形式分析了thinkPHP5.1框架數(shù)據(jù)庫連接的常用方式與針對數(shù)據(jù)庫增刪改查操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2019-08-08