Yii2 如何使用事件
原文地址:http://www.fancyecommerce.com/2016/04/29/yii2-%E4%BD%BF%E7%94%A8event-1-%EF%BC%8C%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8%E4%BA%8B%E4%BB%B6/
1.首先需要 定义 事件传递的数据格式类:
- <?php
- namespace myapp\frontend\code\ECM\Customer\events;
- use Yii;
- use yii\base\Model;
- use yii\base\Event;
- /**
- * ContactForm is the model behind the contact form.
- */
- class MessageEvent extends Event
- {
- public $message;
- }
在这个 MessageEvent 里面就定义了一个变量 $message
2.
编写事件: 事件只要定义个hello 函数,然后参数为 上面第一步分传递的$event 对象,里面包含$message 参数,如果这个Event执行
那么。将会写入日志。
- <?php
- namespace myapp\frontend\code\ECM\Customer\events;
- use Yii;
- /**
- * ContactForm is the model behind the contact form.
- */
- class Ha
- {
- public function hello($event){
- Yii::info($event->message,'mylog');
- }
- }
3
绑定和触发事件
- <?php
- namespace myapp\frontend\code\ECM\Cms\controllers;
- use Yii;
- use myapp\frontend\code\ECM\BaseController;
- use myapp\frontend\code\ECM\Customer\events\Ha;
- use myapp\frontend\code\ECM\Customer\events\MessageEvent;
- class IndexController extends BaseController
- {
- # 定义Event的名字
- const EVENT_HELLO = 'my hello';
- public function actionIndex()
- {
- #定义传递数据的格式 Event
- $event = new MessageEvent;
- # 赋值
- $event->message = 'good';
- # 绑定事件Event 这个事件对应的是:Ha->hello($event);
- $this->on(self::EVENT_HELLO, [new \myapp\frontend\code\ECM\Customer\events\Ha(), 'hello']);
- # 触发事件 ,$event 这个对象传递到 Ha->hello($event);
- $this->trigger(self::EVENT_HELLO,$event);
- return $this->render('index');
- }
- }
从这里看,貌似没有多大用处,直接作为参数调用就行了,两边都写代码麻烦
但是,事件是可以不再文件的函数内书写绑定,可以在new 对象之后再绑定
- $foo = new Foo;
- // 处理器是全局函数
- $foo->on(Foo::EVENT_HELLO, 'function_name');
- // 处理器是对象方法
- $foo->on(Foo::EVENT_HELLO, [$object, 'methodName']);
也可以在Behavior 行为绑定事件。
譬如在一个类保存的时候可以触发一个 保存后的事件
如果这个类没有绑定事件,那么执行为空
如果绑定,就会执行
1.如果一个Event,被多个类执行,一般使用Behavior的方式进行绑定,譬如 Avtive Record 保存后写入log
这种情况一般是自己写的类,使用别人写的,或者自己写的Event。进行一些处理
2.如果是系统的类,类的事件触发已经写好,但是没有绑定事件,默认什么也没有执行,譬如active Record 的 beforeSave操作
对于这种,我们不能去修改系统的代码,所以,我们可以通过$foo->on()的方式进行绑定,然后在执行save操作,就会触发beforeSave();
当然,我们可以定义一个子类,继承ActiveRecord,然后再里面添加行为。
Yii2 如何使用事件的更多相关文章
- yii2 内置事件
1.yii2系统登录 const EVENT_BEFORE_LOGIN = 'beforeLogin'; //登录前 const EVENT_AFTER_LOGIN = 'afterLog ...
- yii2中的事件和行为
Event 事件 事件是为了解耦... 注册事件 使用"on add"添加属性,注册事件 使用on方法注册事件. 第三个参数$data是监听函数使用的参数, 第四个$append参 ...
- Yii2事件
namespace app\components; use yii\base\Component; use yii\base\Event; class MessageEvent extends Eve ...
- Yii 2.0 中事件的使用
关于PHP的事件处理,参照 http://www.cnblogs.com/mafeifan/p/4322238.html http://www.cnblogs.com/mafeifan/p/43222 ...
- Yii2之事件处理
通过事件(Event)处理,可以在某个特定时刻执行指定的代码,可以解耦代码,同时也增加了可维护性,通常,事件在客户端软件中比较好理解,比如onClick,onFocus,当点击按钮,获取到焦点时执行指 ...
- JNI详解---从不懂到理解
转载:https://blog.csdn.net/hui12581/article/details/44832651 Chap1:JNI完全手册... 3 Chap2:JNI-百度百科... 11 C ...
- Yii2的深入学习--事件Event
我们先来看下事件在 Yii2 中的使用,如下内容摘自 Yii2中文文档 事件可以将自定义代码“注入”到现有代码中的特定执行点.附加自定义代码到某个事件,当这个事件被触发时,这些代码就会自动执行.例如, ...
- Yii2之事件
众所周知,yii的三大特性是:属性.事件.行为,上一篇博文简单讲解了yii中的属性,本文接着讲讲yii的事件. 事件是代码解耦的一种方式,设计业务流程的一种模式.在yii2.0中,通过Yii\base ...
- PHP观察者模式与Yii2.0事件
1.先看PHP观察者模式的实现: 想要使用事件.必须实现事件的基类.统一的addObserver和trigger方法 定义统一接口.所有的观察者都要实现此接口 //事件的基类 abstract cla ...
随机推荐
- php基础32:正则匹配-修饰符
<?php //正则表达式--修饰符一般放在//的外面 //1. i 表示不区分大小写 $model = "/php/"; $string = "php" ...
- IT客学院《构建高转化率的着陆页-PS+HTML+网络营销》共25节【价值199元】无水印版
课程简介本课程是全网独家专业的着陆页课程,课程完整的再现了整个着陆页实战案例的开发过程,包括:策划.设计和实现.上线后的推广.优化及提高转化率的技巧等,本套课程能帮助您迅速掌握着陆页的能力,迅速洞察完 ...
- Android -- Scroller
Android里Scroller类是为了实现View平滑滚动的一个Helper类.通常在自定义的View时使用,在View中定义一个私有成员mScroller = new Scroller(conte ...
- PostgreSQL: 一种用于生成随机字符串的方法
create or replace function random_string(integer) returns text as $body$ select array_to_string(arra ...
- Jetty嵌入式Web容器攻略
Jetty是一个用 Java 实现.开源.基于标准的,并且具有丰富功能的 Http 服务器和 Web 容器.Jetty中应用最广泛的一项功能就是可以作为嵌入式Web容器. 在开发阶段,可以使用Jett ...
- C# GC 垃圾回收机制
今天来谈谈C# 的GC ,也就是垃圾回收机制,非常的受教,总结如下 首先:谈谈托管,什么叫托管,我的理解就是托付C# 运行环境帮我们去管理,在这个运行环境中可以帮助我们开辟内存和释放内存,开辟内存一般 ...
- grootJs属性扩展 groot.bindExtend
index12.html <html><head> <title>grootJs属性扩展 groot.bindExtend</title> <sc ...
- Bootstrap系列 -- 31.嵌套分组
我们常把下拉菜单和普通的按钮组排列在一起,实现类似于导航菜单的效果.使用的时候,只需要把当初制作下拉菜单的“dropdown”的容器换成“btn-group”,并且和普通的按钮放在同一级 <di ...
- $().each() 与 $.each()解析
在jquery 中我们可以选择$().each() 与 $.each() 进行迭代对象和数组 $(items).each(function(){ //item }) , 而后者则 $.each(ite ...
- 第十七课:js数据缓存系统的原理
这一章主要讲的是jQuery的缓存系统的历史发展,以及他自己的框架的缓存系统的实现.都是源码解析. 我就挑几个重点讲下: (1)jQuery的缓存机制的原理 jQuery的缓存机制实现的原理是在元素中 ...