`
月影无痕
  • 浏览: 1003563 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Yii组件机制之二:组件的使用及扩展

 
阅读更多

Yii的组件机制详解

应用程序CWebApplication组件

在说明Yii中各个组件使用方法前,先了解最重要的一个组件CWebApplication

CWebApplication即应用程序对象,它的根类也是CComponent,故它也是一个组件,具有Yii组件的共同特征。

具体来说,CWebApplication组件的主要作用是根据配置文件,加载必要的辅助组件,并在这些组件的帮助下(如urlManager)创建并运行控制器。故也将其称为前端控制器。

我们可以在配置文件中指定CWebApplication组件本身的配置参数,这些参数被设置为其公共成员变量,或是自动调用setter方法设置属性,这个特性可以在CWebApplication的构造函数中发现:$this->configure($config);

如在配置文件protected/config/main.php全局中指定:

'charset' => 'utf-8',

这实际是设置当前应用程序的charset公共属性(在CApplication中声明)

而如果在配置文件中指定'language' => 'zh_cn', 我们发现CWebApplication及其所有上级类均未声明$language属性,这时将使用setter模式方法即setlanuage(此方法定义在CApplication类中)。

OK,了解这个特性之后,我们就可以明白在配置文件中可以配置的属性:

1. CWebApplication及其所有上级类的公共成员变量

2. CWebApplication及其所有上级类的setter方法指定的属性

当然我们也可以通过继承CWebApplication构造自己的应用程序类。

CWebApplication的继承层次为:CApplication -> CModule -> CComponent, 我们将默认的配置文件中常见的配置项及其生效位置予以说明:

basePath :  CApplication::setBasePath()

name: CApplication::$name

preload: CModule::$preload

import: CModule::setImport()

defaultController: CWebApplication::$defaultController

components: CModule::setComponents()

类似地,再列出几个默认配置文件中并未列出的配置项:

timezone: CApplication::setTimeZone()  #配置时区

再例如,如果我们继承CWebApplication, 扩展自己的应用程序类myApp, 并定义方法setError_reporting(不区分大小写), 那么就可以直接在配置文件中指定error_reporting选项。

辅助组件

可以将CWebApplication组件视为一部机器,那么辅助组件就可以视为组成这部机器的各个零件,没有零件的正确组合,机器就无法正常工作,这在Yii中也是同样的概念。而一些组件对整部机器的运转是必须的,这就是核心组件。在应用程序对象构造后,Yii会将辅助组件基本信息进行登记(组件名称与类名,属性配置的对照表),以供后续使用,对web应用程序而言,存在以下核心组件(通过CWebApplication::registerCoreComponents,CApplication::registerCoreComponents注册):

CWebApplication::registerCoreComponents中注册的核心组件

组件名称 对应的类 配置参数 说明

session CHttpSession session的封装

assetManager CAssetManager 管理静态资源(css, js等等)

user CWebUser 当前访问用户的封装

themeManager CThemeManager 实现多套模板管理

authManager CPhpAuthManager 通过文件中的用户信息进行验证

clientScript CClientScript 管理客户端使用到的js脚本

widgetFactory CWidgetFactory 生成wiget小部件

CApplication::registerCoreComponents中注册的核心组件

coreMessages CPhpMessageSource 框架文本消息()语言翻译

db CDbConnection 数据库连接

errorHandler CErrorHandler 错误及异常处理(日志记录、错误呈现)

securityManager CSecurityManager 较少使用

statePersister CStatePersister 基于文件的用户状态数据持久化实现

urlManager CUrlManager URL管理(路由双解析实现)

request CHttpRequest 当前请求数据的的封装

format CFormatter 数据格式化功能实现

配置文本中注册的核心组件:

log CLogRouter 日志路由管理器

以上标记为红色的条目,是最重要的辅助组件,其它的核心组件我们未必会使用到。

如何定义辅助组件的属性?

通过在配置文件protected/config/main.php中设置components项的值,实现组件属性定义。这里的定义主要是三个要素:指定组件的名称(核心组件已经预先设置)、指定组件使用的类(核心组件无须定义),组件的属性(可选、视情况而定)

如以下配置:

'components' => array(

'db' => array(

'class' => 'myCDbConnection',

'connnectionString' => 'mysql:host=localhost;dbname=test;charset=utf8',

'user' => 'root',

),

);

就设置了db组件使用的类为myCDbConnection, 并且在后面指定了连接串及账号等信息。

提示: myCDbConnection类可能就是通过继承CDbConnection类定义。

核心组件无须指定class参数(因为已经预先定义好)

问题:如何得知某个组件可配置的属性?

这个问题至关重要,如果我们掌握了规律,就可以举一反三,所有组件的配置均可以灵活设定。授之以鱼不如授之以渔。在本节会说明通用的方法。

要得知组件的所有可定义属性,按以下步骤进行:

1. 组件所使用的类是什么?(无论是核心组件还是自定义组件)

2. 组件类的公共成员变量都有哪些?(注意从父类继承而来的公共成员变量)

3. 组件类都有哪些settter方法?(注意从父类继承而来的方法)

明白了以上三个要点,我们就可以按规律定义组件的属性,比如对最重要的db组件,我们发现这是一个核心组件,使用的类为CDbConnection, 我们查阅这个类的定义文件,发现这个类的公共成员变量有:

$connectionString;

$username='';

$password='';

$autoConnect=true;

$charset;

$emulatePrepare;

$tablePrefix;

$initSQLs;

... ...

setter方法定义的属性:

setActive($value)

setAttributes($values)

setAutoCommit($value)

setColumnCase($value)

setNullConversion($value)

setPersistent($value)

提示:setter方法定义的属性名称不区分大小写

以上所列的属性,均可以在配置文件中指定,具体每个属性的作用,请参阅Yii类文件的详细注释(Yii代码的注释也是相当棒,通俗易懂,而又很详细)

再来一个例子,定义urlManager组件的属性

这个组件使用的类为CUrlManager, 我们查阅它的属性:

$rules=array();

$urlSuffix='';

$showScriptName=true;

$appendParams=true;

$routeVar='r';

$caseSensitive=true;

通过setter方法定义的属性:

setUrlFormat($value)

setBaseUrl($value)

即urlManager组件的上述属性可以在配置文件中定义(每项配置的作用请参阅其注释)。

其它组件的配置均可按上述方法处理。

如何使用组件

应用程序运行后,会将所有已经定义过的组件注册(并未实例化)到CWebApplication对象上,同时CWebApplication应用程序对象会被注册到Yii::$_app,在程序的任何位置均可通过Yii::app()得到当前应用程序对象引用,再通过$app对象得到组件实例引用,如:

Yii::app()->getComponent('urlManager');  #会查找组件配置并实例化之

Yii::app()->urlManager;  #通过CModule::__get()魔术方法实现

如何自定义组件?

这是很常见的需求,比如我们可能希望db组件(数据库连接)使用我们自定义的类,也或者我们希望使用多个数据库连接,这种情况下就需要自定义组件,使用多数据库的例子:

components=>array(

'db' => array(

... ...

),

'mydb'=>array(

'class' => 'myDbConnection',

'connectionString' => 'mysql:host=localhost;dbname=test;charset=utf8',

'tablePrefix' => 'cdb_',

'username' => 'root',

),

),

修改默认的db组件所使用的类:
components=>array(

'db' => array(

'class' => 'myDbConnection',

... ...

),

),

经过本文的分析,我是深切理解了Yii组件化机制给应用程序带来的极大的扩展性。如有任何疑惑,请联系zhangxugg@163.com。另外,Java Beans也是此种机制。常规的编程方式是在使用某个对象时,其所使用的类是已经预先定死的,若要实现扩展,就得修改类代码,这给项目的迭代,版本升级带来极大的麻烦。而使用组件机制就很好地规避了这个问题。

<!--EndFragment-->
1
2
分享到:
评论

相关推荐

    yii2-bootstrap4:Yii 2 Bootstrap 4扩展

    Twitter Bootstrap 4 Yii 2... 它按照Yii小部件封装了组件和插件,因此在Yii应用程序中使用Bootstrap组件/插件非常容易。 有关许可证信息,请检查文件。 文档位于 。 安装 安装此扩展的首选方法是通过 。 无论运行 ...

    yii-resque, 基于 php Resque的Yii组件,基于.zip

    yii-resque, 基于 php Resque的Yii组件,基于 Resque我是 php的一个组件,它基于 php-resque resque和 php-resque-scheduler的组件,我们还通过使用 ResqueBoard测试了日志处理程序 using 。需求php函数扩展。Red

    yii2-bootstrap:Yii 2 Bootstrap 3扩展

    Twitter Yii 2的Bootstrap... 它根据Yii小部件封装了组件和插件,因此在Yii应用程序中使用Bootstrap组件/插件非常容易。 有关许可证信息,请检查文件。 文档位于 。 安装 安装此扩展的首选方法是通过 。 无论运行 ...

    yii2-settings:Yii2 设置组件

    Yii2 设置组件 安装 安装此扩展的首选方法是通过 。 要么跑 php composer.phar require --prefer-dist pendalf89/yii2-settings "*" 或添加 "pendalf89/yii2-settings": "*" 到composer.json文件的 require 部分...

    yii2-jstree:Yii2 jsTree 组件

    Yii2 jsTree 组件jsTree 是 jquery 插件,提供交互式树。 它是完全免费的、开源的,并在 MIT 许可下分发。 jsTree 易于扩展、主题化和可配置,它支持 HTML 和 JSON 数据源以及 AJAX 加载。 这个包允许你在几分钟内将...

    yii2-redis:Yii 2 Redis扩展

    Yii 2的Redis缓存,会话和ActiveRecord 该扩展为提供了键值存储支持。 它包括一个Cache和Session存储处理程序,并实现...要使用此扩展,您必须在应用程序配置中配置Connection类: return [ //.... 'components

    yii2-fullcalendar:Yii 2组件,可轻松实现全日历集成

    Yii2全日历组件 安装 安装此扩展的首选方法是通过 。 要安装,请运行 $ php composer.phar require edofre/yii2-fullcalendar "V1.0.11" 或添加 "edofre/yii2-fullcalendar": "V1.0.11" 到composer.json文件的...

    yii2-curl:用于 curl 的 Yii2 组件

    php composer.phar require --prefer-dist peterfrench/yii2-curl " * " 一旦 composer 安装了扩展,在您的配置文件中包含该组件。 'curl' =&gt; ['class' =&gt; 'peterfrench\curl\Curl' ,'options' =&gt; [/* curl options...

    yii扩展--ip地址识别--QQWRY

    YII扩展 IP地址识别组件 采用QQWRY数据库 使用条件: 解压到相应的目录。 确定QQWRY.DAT 放入 protacted/data 确定IpLocation 放入 protacted/components 修改main.php 'components'=&gt;array( //......

    yii2-uikit:Yii框架的UIkit前端框架扩展

    它根据Yii小部件封装了UIkit组件和插件,因此在Yii应用程序中使用UIkit组件/插件非常容易。 例如,视图文件中的以下单行代码将呈现一个Progress插件: &lt;?= artkost\uikit\ Progress :: widget ([ 'percent' =&gt; ...

    yii2-dialog:一种扩展,用于包装Yii 2.0框架的bootstrap3-dialog

    Yii Framework 2.0的小部件组件,可轻松配置和初始化弹出通知对话框。 它为本机javascript警报,确认和提示对话框提供了一个polyfill。 它包括对通过呈现丰富对话框的内置支持,这使得使用Bootstrap的模态对猴子更...

    yii2-recaptcha:谷歌 reCAPTCHA 的 Yii2 扩展

    谷歌 reCAPTCHA 的 Yii2 扩展 ReCAPTCHA 允许您在网页中嵌入验证码,以保护它们免受垃圾邮件和其他类型的自动滥用。 安装 将 reCAPTCHA 添加到您的站点包括三个步骤: 显示小部件 验证用户的响应 安装此扩展的首选...

    yii2-vueapp:一个在不使用webpack或类似工具的情况下在Yii2中创建Vue应用的Vue.js帮助器

    这是一个有助于创建Vue.js应用程序的组件,无需使用易用的webpack或类似组件。 所有资产(js,css和模板)都直接注入html中,并且此组件提供了拆分代码(js,css和模板)并从html根元素加载参数的功能。 此组件...

    yii2-rocketsms:SMS提供商RocketSMS.by的Yii2组件

    yii2-rocketsms SMS提供商RocketSMS.by的Yii2组件安装安装此扩展的首选方法是通过 。 无论运行 php composer.phar require ozerich/yii2-rocketsms "*"或添加 "ozerich/yii2-rocketsms": "*"到composer.json文件的...

    yii2-mailqueue, 用于 yii2 swiftmailer https的yii2的电子邮件队列组件.zip

    yii2-mailqueue, 用于 yii2 swiftmailer https的yii2的电子邮件队列组件 yii2-mailqueue适用于 yii2-swiftmailer的yii2的电子邮件队列组件安装安装这个扩展的首选方法是通过 composer插件。运行...

    yii2-cart:Yii2购物车

    Yii2购物车扩展 此扩展添加了Yii Framework 2.0的购物车 支持我们 您的业​​务是否取决于我们的贡献? 伸出援手并在上支持我们。 所有的承诺都将致力于分配劳动力进行维护和购买新产品。 安装 安装此扩展的首选方法...

    Yii扩展组件编写方法实例分析

    主要介绍了Yii扩展组件编写方法,实例分析了Yii框架下扩展组件的实现技巧,需要的朋友可以参考下

    yii2-queue-mailer:Yii2框架的队列邮件装饰器

    Yii2框架的队列邮件装饰器使用Yii2队列在后台发送您的电子邮件。安装安装此扩展的首选方法是通过 。 无论运行php composer.phar require --prefer-dist yarcode/yii2-queue-mailer 或添加" yarcode/yii2-queue-...

    yii2-queue:Yii2的排队系统

    Yii2的队列组件 这为Yii2提供了队列组件。 要求 您需要启用才能运行侦听器 安装 安装此扩展的首选方法是通过 。 无论运行 php composer.phar require --prefer-dist urbanindo/yii2-queue "*" 或添加 "urbanindo/...

    yii2-arangodb:yii2 框架的 ArangoDB 组件

    Yii 2 的 ArangoDb 扩展这个扩展为 Yii2 框架提供了集成。安装此扩展需要安装此扩展的首选方法是通过 。 要么跑 php composer.phar require --prefer-dist devgroup/yii2-arangodb "*"或添加 "devgroup/yii2-...

Global site tag (gtag.js) - Google Analytics