一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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
主站蜘蛛池模板: 成人夜视频寂寞在线观看 | 成人在线视频国产 | 奇米网在线 | 国产精品中文字幕 | 乌克兰少妇大胆大BBW | 2019中文字幕| 艹出白浆| 精品综合久久久久久88小说 | 农村妇女野战bbxxx农村妇女 | 成人午夜爽爽爽免费视频 | 四神集团1涨奶是第几章 | 色综合久久中文字幕 | 亚洲成年人免费网站 | 娇妻被朋友征服中文字幕 | 欧美日韩一区视频 | 校园纯肉H教室第一次 | 毛片免费全部免费观看 | 特黄特色大片免费影院 | jzzjlzz亚洲乱熟在线播放 | 九九在线精品亚洲国产 | 日韩成人免费aa在线看 | 日本高清视频在线免费观看 | 大奶妈咪女教师 | 网友偷自拍原创区 | 亚洲一区二区福利视频 | 日本高清在线看免费观看 | 国产区1| 成人国产精品一区二区不卡 | 欧美生活一级片 | 日本sss在线高清观看 | 99久久精品免费观看区一 | 久久亚洲电影www电影网 | 国产良心大作白丝精厕 | 日本xx高清视频免费观看 | 青草国产在线视频 | 99性视频| 亚洲 日韩 自拍 视频一区 | 四虎欧美 | 亚洲 欧美 另类 中文 在线 | 国产亚洲福利一区二区免费看 | 99精品热|