Zend Framework教程之资源(Resources)用法实例详解
本文实例讲述了zend framework教程之资源(resources)用法。分享给大家供大家参考,具体如下:
zend_application_resource_resource
zend_application_bootstrap_resourcebootstrapper是引导类加载注册资源插件使用的接口。
zend_application_resource_resource是一个资源插件接口。
zend_application_resource_resource通常被用于实现了zend_application_bootstrap_resourcebootstrapper的引导类中。
资源插件是一个可配置,预加载的和可以通过策略模式初始化资源的接口。
zend_application_resource_resource interface
method | return value | parameters | description |
---|---|---|---|
__construct($options = null) | void |
|
|
setbootstrap(zend_application_bootstrap_bootstrapper $bootstrap) | zend_application_resource_resource |
|
|
getbootstrap() | zend_application_bootstrap_bootstrapper | n/a |
|
setoptions(array $options) | zend_application_resource_resource |
|
|
getoptions() | array | n/a |
|
init() | mixed | n/a |
采用策略模式: 运行,初始化资源. |
zend_application_resource_resourceabstract
zend_application_resource_resourceabstract是一个抽象类,实现了zend_application_resource_resource接口,为创建自定义插件资源提供了一个便捷的方式。
注:这个抽象类没有实现init()方法,可以继承使用这个抽象类,自定义实现init方法。
zend_application_resource_resourceabstract methods
method | return value | parameters | description |
---|---|---|---|
__construct($options = null) | void |
|
|
setbootstrap(zend_application_bootstrap_bootstrapper $bootstrap) | zend_application_resource_resourceabstract |
|
|
getbootstrap() | zend_application_bootstrap_bootstrapper | n/a |
|
setoptions(array $options) | zend_application_resource_resourceabstract |
|
|
getoptions() | array | n/a |
|
资源名称
注册插件资源时,出现的一个问题是你应该如何从父引导类。有三种不同的机制,可以使用,这取决于你是如何配置的引导和它的插件资源。
首先,如果你的插件名称定义包含前缀路径,您可以通过他们的“短名称” - 即类的名称的一部分。例如,类“zend_application_resource_view”的短名称是“view”,如果前缀路径“zend_application_resource”已注册。您可能使用类的全名或短名称注册他们:
$app = new zend_application(application_env, array( 'pluginpaths' => array( 'my_resource' => 'my/resource/', ), 'resources' => array( // if the following class exists: 'my_resource_view' => array(), // then this is equivalent: 'view' => array(), ), ));
以后可以使用短名称引导资源和获取:
$bootstrap->bootstrap('view'); $view = $bootstrap->getresource('view');
其次,如果没有匹配的插件路径的定义,你可能仍然通过使用资源类的全名。在这种情况下,你可以参考如下使用资源的完整类名:
$app = new zend_application(application_env, array( 'resources' => array( // this will load the standard 'view' resource: 'view' => array(), // while this loads a resource with a specific class name: 'my_resource_view' => array(), ), ));
引导资源以及获取方式
$bootstrap->bootstrap('my_resource_view'); $view = $bootstrap->getresource('my_resource_view');
这给我们带来了第三个选项。您可以指定一个明确的名称,将自己注册为一个给定的资源类。这可以通过资源插件类增加 public $_explicittype的字符串值,该值将被用来指定引导插件资源。作为一个例子,让我们来定义我们自己的视图类:
class my_resource_view extends zend_application_resource_resourceabstract { public $_explicittype = 'my_view'; public function init() { // do some initialization... } }
然后,我们可以引导资源或通过它的名字“my_view”获取:
$bootstrap->bootstrap('my_view'); $view = $bootstrap->getresource('my_view');
可以使用这些不同的命名方法,覆盖现有资源,添加您自己的,混合是i用多种资源,以实现复杂的初始化等等。
更多关于zend相关内容感兴趣的读者可查看本站专题:《zend framework框架入门教程》、《php优秀开发框架总结》、《yii框架入门及常用技巧总结》、《thinkphp入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家php程序设计有所帮助。
推荐阅读
-
Zend Framework教程之资源(Resources)用法实例详解
-
Zend Framework教程之Loader以及PluginLoader用法详解
-
Zend Framework教程之Autoloading用法详解
-
Zend Framework教程之Zend_Controller_Plugin插件用法详解
-
Zend Framework教程之响应对象的封装Zend_Controller_Response实例详解
-
Zend Framework教程之Resource Autoloading用法实例
-
Zend Framework教程之Application和Bootstrap用法详解
-
Zend Framework教程之请求对象的封装Zend_Controller_Request实例详解
-
Zend Framework教程之前端控制器Zend_Controller_Front用法详解
-
Zend Framework动作助手Redirector用法实例详解