zoukankan      html  css  js  c++  java
  • php设计模式 观察者模式

    观察者模式的核心是把客户元素(观察者)从一个中心类(主体)中分离开来。当主体知道事件发生时,观察者需要被通知到。同时,我们并不希望将主体与观察者之间的关系进行硬编码。为了达到这个目的,我们可以允许观察者在主体上进行注册。

    观察者模式实现了低耦合、非侵入式的通知与更新机制。

    场景:当一个事件发生后,要执行一连串更新操作。

    EventGenerator.php
    <?php
    namespace Baobab;
    /**
     * Class EventGenerator 基类,事件发生者
     */
    abstract class EventGenerator{
    
        //观察者对于事件发生者是不可见的,事件发生者不关心有哪些观察者关注了事件
        private $observers = array();
    
        /**
         * 添加观察者
         */
        function addObserver(Observer $observer){
            $this->observers[] = $observer;
        }
    
        /**
         *逐个通知观察者进行更新的操作
         */
        function notify(){
            foreach($this->observers as $observer){
                $observer->update();
            }
        }
    }
    Observer.php
    <?php
    namespace Baobab;
    /**
     * Class Observer 观察者,观察的对象是事件发生者
     * @package Baobab
     */
    interface Observer{
        /**
         * @param null $event_info  事件的信息
         * 表示事件发生后进行更新的操作
         */
        function update($event_info = null);
    }

    index.php

    class Event extends BaobabEventGenerator{
        /**
         *触发一个新的事件
         */
        function trigger(){
            echo 'Event发生';
            $this->notify();
        }
    }
    
    /**
     * 观察者1
     */
    class Observer1 implements BaobabObserver{
        function Update($event_info = null){
            echo '更新操作代码1';
        }
    }
    /**
    * 观察者2
    */
    class Observer2 implements BaobabObserver{ function Update($event_info = null){ echo '更新操作代码2'; } } $event = new Event(); $event->addObserver(new Observer1()); $event->addObserver(new Observer2()); $event->trigger();
  • 相关阅读:
    移动端 提交按钮呗软键盘挤上去的问题解决
    jenkins创建项目API踩坑记
    backstage使用笔记(2)- 跨域代理设置
    backstage使用笔记(1)- 项目的搭建和插件的创建
    什么是强缓存,什么是协商缓存?
    关于antd英文文案切换为中文
    记解决遇到自己电脑看线上项目没问题,别的同事电脑看线上项目有问题的疑难杂症
    vue.js组件传值
    Vue.js组件
    关于Object.keys()和for in的区别
  • 原文地址:https://www.cnblogs.com/tianxintian22/p/5238105.html
Copyright © 2011-2022 走看看