国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - js簡單粗暴的發(fā)布訂閱示例代碼

js簡單粗暴的發(fā)布訂閱示例代碼

2022-01-06 15:19威威威威vvvv js教程

這篇文章主要給大家介紹了js簡單粗暴的發(fā)布訂閱的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

什么是發(fā)布/訂閱?

我打個比方,你去某個門店買衣服,你和門店店長相互并不認識,門店店長只管賣他的衣服,并不關心是誰來買,而你也只管買你想要的衣服,并不關心是哪個門店在賣,這時,門店和你就組成了一個發(fā)布/訂閱的關系。

當門店掛出衣服款式,你去找你想要的衣服,如果找到了,那就買下來,如果沒找到,那就離開這家店。整個過程就是這么簡單。

使用場景

異步通信、多頁面間相互通信,pageA 的方法想在 pageB的方法調(diào)用的某個時機觸發(fā)

直接上代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
class Publish {
 constructor() {
  this.listMap = {};
 }
    // 訂閱
 on(key, fn) {
  this.listMap[key]
   ? this.listMap[key].push(fn)
   : this.listMap[key] = [fn];
   
        // 存儲訂閱fn的下標
  const index = this.listMap[key].length - 1;
  
        // 返回取消訂閱的function
  return () => this.clear(key, index);
 }
 
    // 取消所有該key訂閱
 off(key) {
  delete this.listMap[key];
 }
 
    // 取消key的指定的某個訂閱
 clear(key, index) {
  index === this.listMap[key].length - 1
   ? this.listMap[key].pop()
   : this.listMap[key][index] = null;
 }
 
    //訂閱一次觸發(fā)后自動取消訂閱
 once(key, fn) {
  this.on(key, (...rest) => {
   fn(...rest);
   this.off(key);
  });
 }
 
    // 發(fā)布key
 trigger(key, ...rest) {
    if(key in this.listMap) {
        this.listMap[key].forEach(fn => {
       fn(...rest);
      });
    }
 }
}

使用方法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
const ob = new Publish();
 
// 訂閱 sub1
const sub1 = ob.on('sub1', (a, b) => {
 console.log('sub1', a, b);
});
 
// 訂閱 sub1
const sub11 = ob.on('sub1', (a, b) => {
 console.log('sub11', a, b);
});
 
ob.trigger('sub1', 2, 3);
 
// 取消訂閱sub1
sub1();
 
// 取消訂閱sub11
sub11();
 
// 訂閱 sub3
ob.on('sub3', (a, b) => {
 console.log('sub3', a, b);
});
 
// 訂閱 sub3
ob.on('sub3', (a, b) => {
 console.log('sub33', a, b);
});
 
ob.trigger('sub3', 6, 7);
 
// 取消訂閱所有的sub3
ob.off('sub3');
 
// 訂閱一次就自行取消訂閱
ob.once('sub4', (a, b) => {
 console.log('sub4', a, b);
});
 
ob.trigger('sub4', 8, 9);

總結

到此這篇關于js簡單粗暴的發(fā)布訂閱的文章就介紹到這了,更多相關js簡單發(fā)布訂閱內(nèi)容請搜索服務器之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_41964594/article/details/112942774

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品久久久久久久久久久久 | 欧美性久久 | 成人午夜精品一区二区三区 | 日韩精品在线一区 | 色噜噜视频在线观看 | 久久久久久久国产精品视频 | 欧美成人免费电影 | 综合导航 | 欧美黑人狂躁日本寡妇 | 成人国产精品久久 | 日韩欧美a级v片免费播放 | 国产亚洲欧美一区二区 | 日比毛片 | 国产精品久久久久久福利一牛影视 | 亚洲视频在线观看视频 | 午夜精品久久久久久久久 | 日韩三级电影网 | 精品久久av | 免费激情网站 | 成人精品99| 亚洲国产成人av | 成人久久久久久 | 欧美日韩亚洲综合 | 97超碰在线免费 | 国产二区视频 | 亚洲男人av| 91国内外精品自在线播放 | 亚洲一本 | 久久99视频 | 免费在线观看毛片 | 日韩免费视频 | 亚洲电影在线观看 | 久久av网站 | 亚洲视频一区在线播放 | 欧美中文字幕在线观看 | 午夜视频精品 | 污视频在线观看免费 | 羞羞网站在线观看 | 日韩不卡一二三 | 二区影院| 欧美日韩亚洲系列 |