前端-发布订阅模式

class EventBus {
  constructor() {
    this.events = {}
  }

  /**
   * @desc 监听事件
   * @param {String} name 事件名
   * @param {Function} callback 回调函数
   */
  on(name, callback) {
    this.events[name] ? this.events[name].push(callback) : this.events[name] = [callback]
  }

  /**
   * @desc 触发事件
   * @param {String} name 事件名
   * @param {Function} params 参数
   */
  trigger(name, params) {
    this.events[name] && Array.isArray(this.events[name]) && this.events[name].forEach(callback => callback(params))
  }

  /**
   * @desc 销毁
   * @param {String} name 事件名
   */
  off(name, handler) {
    let handlers = this.events[name]
    if (handlers) {
      // 清空对应的handle
      handlers.splice(handlers.indexOf(handler) >>> 0, 1)
    }
  }
  /**
   * 销毁所有name的事件
   * @param {String} name 
   */
  offAll(name) {
    this.events[name] = []
  }
}
export default new EventBus()

简易版本:直接在 utils 文件夹中新建 utils 中添加方法即可
 

module.exports = function (n) {
    return {
        all: n = n || new Map,
        on: function (e, t) {
            var i = n.get(e); i && i.push(t) || n.set(e, [t])
        },
        off: function (e, t) {
            if (t) {
                var i = n.get(e);
                i && i.splice(i.indexOf(t) >>> 0, 1)
            } else {
                var i = n.get(e);
                i && i.splice(0, i.length)
            }
        },
        emit: function (e, t) {
            (n.get(e) || []).slice().map(function (n) { n(t) }), (n.get("*") || []).slice().map(function (n) { n(e, t) })
        }
    }
};

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MVVM 是一种前端架构设计模式,它将界面、数据和逻辑分离并通过 ViewModel 进行交互。在 MVVM 模式中,视图(View)和模型(Model)是完全独立的,它们通过 ViewModel 进行双向绑定(Binding)。 在 Vue.js 中,MVVM 模式被称为“响应式编程”,它的核心是数据劫持和发布订阅模式。Vue.js 的数据驱动视图,通过数据改变来更新视图,这些数据是被劫持的,也就是说,当数据发生变化时,Vue.js 会自动更新视图。 Vue.js 中的 MVVM 模式包含以下三个部分: 1. 视图层(View):负责展示数据,通常是 HTML 模板。 2. 模型层(Model):负责存储数据,通常是 JavaScript 对象。 3. 视图模型层(ViewModel):负责处理视图与模型之间的交互,它是一个纯粹的 JavaScript 对象,负责实现数据绑定、数据格式化、事件监听等功能。 在 Vue.js 中,我们可以使用指令(v-directive)来实现数据绑定。指令是一种特殊的 HTML 属性,它的值通常是一个表达式,用来绑定指令所在元素的属性或事件。例如,v-bind 指令可以将一个 JavaScript 对象绑定到 DOM 元素的属性,v-on 指令可以监听 DOM 元素的事件。 除了指令之外,Vue.js 还提供了计算属性(Computed)和侦听器(Watch)等功能,用于处理数据的计算和监听数据的变化。 总之,MVVM 模式是一种前端架构设计模式,它通过 ViewModel 实现视图(View)和模型(Model)之间的双向绑定(Binding),实现了数据的自动更新和视图的响应式。在 Vue.js 中,MVVM 模式被称为“响应式编程”,它的核心是数据劫持和发布订阅模式

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清云随笔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值