激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

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

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

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

js簡單粗暴的發布訂閱示例代碼

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

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

什么是發布/訂閱?

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

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

使用場景

異步通信、多頁面間相互通信,pageA 的方法想在 pageB的方法調用的某個時機觸發

直接上代碼

?
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;
 }
 
    //訂閱一次觸發后自動取消訂閱
 once(key, fn) {
  this.on(key, (...rest) => {
   fn(...rest);
   this.off(key);
  });
 }
 
    // 發布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簡單粗暴的發布訂閱的文章就介紹到這了,更多相關js簡單發布訂閱內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

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

延伸 · 閱讀

精彩推薦
  • js教程JavaScript中arguments的使用方法詳解

    JavaScript中arguments的使用方法詳解

    這篇文章主要給大家介紹了關于JavaScript中arguments的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    等待的L先生3672021-12-15
  • js教程微信小程序之高德地圖多點路線規劃過程示例詳解

    微信小程序之高德地圖多點路線規劃過程示例詳解

    這篇文章主要介紹了微信小程序之高德地圖多點路線規劃過程示例詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的...

    heli步籬6562022-01-04
  • js教程原生JavaScript實現輪播圖

    原生JavaScript實現輪播圖

    這篇文章主要為大家詳細介紹了原生JavaScript實現輪播圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    棟棟很優秀啊6932021-12-29
  • js教程原生js實現自定義難度的掃雷游戲

    原生js實現自定義難度的掃雷游戲

    這篇文章主要為大家詳細介紹了原生js實現自定義難度的掃雷游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    清歡灬6392022-01-06
  • js教程js用正則表達式篩選年月日的實例方法

    js用正則表達式篩選年月日的實例方法

    在本篇文章里小編給大家整理的是一篇關于js用正則表達式篩選年月日的實例方法,對此有興趣的朋友們可以學習下。...

    小妮淺淺11862021-12-24
  • js教程在JavaScript中查找字符串中最長單詞的三種方法(推薦)

    在JavaScript中查找字符串中最長單詞的三種方法(推薦)

    這篇文章主要介紹了在JavaScript中查找字符串中最長單詞的三種方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋...

    Hunter網絡安全7292022-01-04
  • js教程微信小程序實現登錄注冊功能

    微信小程序實現登錄注冊功能

    這篇文章主要介紹了微信小程序實現登錄注冊功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    保護我方豆豆5202021-12-22
  • js教程詳解uniapp的全局變量實現方式

    詳解uniapp的全局變量實現方式

    這篇文章主要介紹了詳解uniapp的全局變量實現方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    繭君10792021-12-29
主站蜘蛛池模板: 国产91丝袜在线播放 | 精品一区二区三区不卡 | 欧美性猛交xxx乱大交3蜜桃 | 72pao成人国产永久免费视频 | 水卜樱一区二区av | 国产精品久久久久久久久久三级 | 日本视频免费看 | 桥本有菜免费av一区二区三区 | 香蕉视频99| 成人一级视频在线观看 | 欧美日韩成人一区二区 | 黄色免费网站在线播放 | 高潮娇喘嗯啊~文字 | 久久国产精品二国产精品中国洋人 | 91精品国产乱码久久久久久久久 | 国产精品视频久久久 | 天天操天天插 | 久久久久国产精品久久久久 | 偿还的影视高清在线观看 | 久久免费看片 | 毛片免费看网站 | 国产亚洲精品久久久久久久久久 | 精品国产91久久久久久久妲己 | 精品国产一区二区三区久久久蜜 | 成片免费观看视频大全 | 黄色免费观看网站 | 中国黄色一级生活片 | 亚洲网在线 | 日本精品免费观看 | 欧美性激情视频 | 91av原创 | 精品国产91久久久久久浪潮蜜月 | 久久九九热re6这里有精品 | 黄色羞羞视频在线观看 | 国产 日韩 一区 | 亚洲最新黄色网址 | 亚洲成人激情在线 | 欧美国产综合视频 | 亚洲国产视频网 | 欧美精品网址 | 九九热在线精品视频 |