JS实现Observable观察者模式

欢迎讨论与交流 : )

  

    代码参考自——汇智网 RxJS教程

  前言

    Observable观察者模式令小白笔者眼前一亮。数据生产者(observable)负责生产新鲜的数据,同时在生产完毕后‘通知“消费者”:“hey!哥们,货已经准备好了,你可以过来拿啦!”

  代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>

<body>
    <div class="ez-led" id="clock">00:00:00</div>

    <script type="text/javascript">
        var Observabel = function(generator) {
            // 构造函数 generator 1. 定义数据生产的动作 2. generator内必有‘通知‘消费者的动作(函数)
            this._generator = generator;
        }
        Observabel.prototype.subscribe = function(Observer) {
            // 链接生产者与消费者
            this._generator.call(this, Observer);
        }
        var Observer = function(consumer) {
            // 数据消费者 定义数据消费的动作
            this._consumer = consumer;
        }
        Observer.prototype.onNotify = function(data) {
           // 触发消费者“消费”这一动作
            this._consumer.call(this, data)
        }
        window.onload = function() {
            var elClock = document.getElementById(‘clock‘);
            var getTime = function() {
                var _ = [‘00‘, ‘01‘, ‘02‘, ‘03‘, ‘04‘, ‘05‘, ‘06‘, ‘07‘, ‘08‘, ‘09‘], //补零
                    d = new Date(),
                    h = d.getHours(),
                    m = d.getMinutes(),
                    s = d.getSeconds();
                return [_[h] || h, _[m] || m, _[s] || s].join(":");
            }
            var uiRefresh = new Observer(function(data) {
              elClock.textContent = data
            })
            var tickStream = new Observabel(function(observer) {
                setInterval(function() {
                      // 生产者内调用消费者的“通知”动作
                      observer.onNotify(getTime())
                }, 1000)
                // 链式调用:连接数据生产者与消费者
            }).subscribe(uiRefresh);
        }
    </script>
</body>

</html>
时间: 2024-10-03 02:15:45

JS实现Observable观察者模式的相关文章

js 设计模式之观察者模式

观察者模式 又被称为"发布-订阅"模式,目的是解决主题对象和观察者之间功能的耦合性.发布者和订阅者之间是互不干扰的,没有联系的,通过观察者,当做中介,将二者联系起来. 例子:以学生和老师之间的为例 1.首先创建观察者对象 //将观察者放在闭包中,当页面加载就立即执行 var Observer = (function () { //防止消息队列暴露而被篡改顾将消息容器作为静态私有变量保存 var _message = {}; return { //注册信息接口 regist: funct

js中的观察者模式

什么事观察者模式: 这是一种创建松散耦合代码的技术.它定义对象间 一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知.由主体和观察者组成,主体负责发布事件,同时观察者通过订阅这些事件来观察该主体.主体并不知道观察者的任何事情,观察者知道主体并能注册事件的回调函数. 代码: function EventT(){ this.handlers = {}; } EventT.prototype = { custructor : EventT, addHanler : fun

Js面向对象之观察者模式

//模拟一个目标可能拥有的一些列依赖 function ObserverList() { this.observerList = []; }; //添加一个观察者 ObserverList.prototype.Add = function (obj) { return this.observerList.push(obj); }; //清除所有观察者 ObserverList.prototype.Empty = function () { this.observerList = []; }; /

js 自定义事件观察者模式(发布/订阅)

/* * 示例: * Event.create("namespace1").listen('click', function(a){ * console.log(a); * }); * Event.create("namespace1").trigger("click", 1); */ window.myEvent = (function() { var global = this, Event, _default = 'default'; Ev

js 之观察者模式

观察者模式又叫发布订阅模式(Publish/Subscribe),它定义了一种一对多的关系,让多个观察者对象同时监听某一个主题对象,这个主题对象的状态发生变化时就会通知所有的观察者对象,使得它们能够自动更新自己. 使用观察者模式的好处: 支持简单的广播通信,自动通知所有已经订阅过的对象. 页面载入后目标对象很容易与观察者存在一种动态关联,增加了灵活性. 目标对象与观察者之间的抽象耦合关系能够单独扩展以及重用. JS里对观察者模式的实现是通过回调来实现的,我们来先定义一个pubsub对象,其内部包

js实现观察者模式

基本概念介绍 观察者(observer) 模式广泛用于客户端Javascript编程中.所有的浏览器事件都是该模式的例子.它的另一个名字也称为自定义事件(custom events),与那些由浏览器触发的事件相比,自定义事件表示是由你编程实现的事件.此外,该模式的另一个别名也称为订阅/发布(subscriber/publisher)模式. 设计该模式背后的主要动力是促进形成松散耦合.在这种模式中,并不是一个对象调用另一个对象的方法,而是一个对象订阅另一个对象的特定活动并在状态改变后获得通知.订阅

深入理解JavaScript系列(32):设计模式之观察者模式

介绍 观察者模式又叫发布订阅模式(Publish/Subscribe),它定义了一种一对多的关系,让多个观察者对象同时监听某一个主题对象,这个主题对象的状态发生变化时就会通知所有的观察者对象,使得它们能够自动更新自己. 使用观察者模式的好处: 支持简单的广播通信,自动通知所有已经订阅过的对象. 页面载入后目标对象很容易与观察者存在一种动态关联,增加了灵活性. 目标对象与观察者之间的抽象耦合关系能够单独扩展以及重用. 正文(版本一) JS里对观察者模式的实现是通过回调来实现的,我们来先定义一个pu

[Poi] Use Poi to Build an Index.js with Modern JavaScript Features

Poi can easily launch an index.js file simply by running the poi command. This will launch a dev-server and automatically reload whenever you make changes. You can also npm install any package you need and import it right away. Install: npm install -

如何定义一个高逼格的原生JS插件

转自:https://www.jianshu.com/p/205a4033010a 如何定义一个高逼格的原生JS插件 作为一个前端er,如果不会写一个小插件,都不好意思说自己是混前端界的.写还不能依赖jquery之类的工具库,否则装得不够高端.那么,如何才能装起来让自己看起来逼格更高呢?当然是利用js纯原生的写法啦.以前一直说,掌握了js原生,就基本上可以解决前端的所有脚本交互工作了,这话大体上是有些浮夸了.不过,也从侧面说明了原生js在前端中占着多么重要的一面.好了.废话不多说.咱们就来看一下