dojo.publish 和 dojo.subscribe
来源:互联网 发布:淘宝店铺降权多久恢复 编辑:程序博客网 时间:2024/04/30 10:57
这俩个函数都与事件紧密相关.
-- dojo.subscribe(/*String*/topic, /*Object|null*/context, /*String|Function*/method) 订阅一个主题
-- dojo.publish(/*String*/topic, /*Array*/ args) 发布一个主题
先抛开这两个函数, 现在有一个函数
- function topic() {
- console.log("I'm the topic.");
- }
它仅打印包含自己名字的一句话. 现在我们想在 topic() 被调用的时候 同时调用下面这个 listener() 函数.
- function listener() {
- console.log("I'm a listener.");
- }
最容易想到的方法就是:
- function topic() {
- console.log("I'm the topic.");
- //add here
- listener();
- }
这样做缺点很明显:
1. 如果我还想随着 topic() 的调用, 调用更多的函数如 listener1(), listener2(), ..., listenern(), 就得不断地去修改 topic() 的代码.
2. topic() 与 listener() 函数之间紧耦合
dojo.subscribe and dojo.publish 机制很好的解决了这个问题.
我们知道 JavaScript 函数也是对象, 也可以有属性.
如果给上面的 topic 函数加一个数组类型的属性 _listeners[] , 它记录着像上面例子中的 listener1(), listener2() 这样的函数
并通过 dojo.subscribe() 可以随意随时的向 _listeners[] 里面加入 listener() 函数. dojo.unsubscribe() 移除 _listeners[] 里面的指定函数.
dojo.publish() 就起到了一个调用的作用, 它调用 topic() 函数, 并且遍历 _listeners[] 数组里的所有 listener() 函数, 并调用它们.
简单的说 dojo sub / pub 就是这样工作的, 想了解具体实现细节去读 connect.js 和 event.js(DOM事件相关).
- dojo.publish 和 dojo.subscribe
- 一句话解释 dojo.publish 和 dojo.subscribe
- DOJO subscribe & publish
- dojo
- dojo
- Dojo
- dojo
- dojo
- dojo
- Publish~Subscribe
- dojo是什么和为什么选择dojo
- Dojo Deferreds 和 Promises
- dojo:DOM 和HTML
- Meteor中subscribe和publish简单介绍
- redis 订阅(subscribe/psubscribe)和发布 (publish)
- Dojo Learning: Dojo.data
- dojo :dojo.xhrGet
- Dojo入门:初识Dojo
- 12 虚函数与多态
- 企业版苹果开发者帐号申请
- U盘安装winows各种系统
- MySQL数据库关键字<1>
- javascript篇一
- dojo.publish 和 dojo.subscribe
- linux删除普通用户报错 userdel: user fancy is currently used by process 1973
- 分布式 Key-Value 存储系统:Cassandra 入门
- Java8-流-简介
- KVM虚拟机
- 13 函数模板与类模板
- 卡尔曼滤波(一阶和二阶)
- Windows下Python多版本共存 (2.7 3.5)
- Navicat、SQLyog导入数据库遇到的问题