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