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

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - 微信小程序如何監(jiān)聽全局變量

微信小程序如何監(jiān)聽全局變量

2022-02-25 16:28Vegetable_dog js教程

這篇文章主要給大家介紹了關(guān)于微信小程序如何監(jiān)聽全局變量的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

最近工作上遇到一個(gè)問題,有個(gè)全局變量 red_heart,因?yàn)樗诤芏嗟胤接玫剑?dāng)它發(fā)生改變了,用到的地方也要改變。但是原生小程序并沒有像Vue這種相關(guān)的做法。所以我就想自己實(shí)現(xiàn)一個(gè)全局變量改變,用到這個(gè)變量的地方也重新渲染。

微信小程序如何監(jiān)聽全局變量

開始吧

首先全局變量里肯定要先有這個(gè) red_heart

?
1
2
3
globalData: {
    red_heart:0,
  },

然后要在onLaunch方法里給全局變量加一個(gè)Proxy代理。

Proxy很好理解,懂得都懂。

?
1
2
3
4
5
6
7
8
9
10
11
this.globalData = new Proxy(this.globalData, {
      get(target, key){
        return target[key];
      },
      set:(target, key, value)=>{
        if(key === "red_heart"){
          this.globalDep.RedHeartDep.notifuy()
        }
        return Reflect.set(target, key, value);
      }
    });

主要看set方法里面有一個(gè)this.globalDep.RedHeartDep.notifuy(),這個(gè)是啥。這是我在全局創(chuàng)建的一個(gè)Dep,簡(jiǎn)稱依賴收集。

代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
globalDep:{
    RedHeartDep:{
      subs:[],
      addSub(watch){
        this.subs.push(watch)
      },
      removeWatch(id){
        this.subs = this.subs.filter((item)=>{
          return item.id != id
        })
      },
      notifuy(){
        setTimeout(()=>{
          this.subs.forEach(w=>w.update())
        },0)
      }
    }
  }

subs是一個(gè)數(shù)組,用來收集依賴,addSub和removeWatch,notifuy是用來告訴這個(gè)東西要去更新了。

那現(xiàn)在還有一個(gè)問題,就是這個(gè)依賴在哪里添加呢,當(dāng)然是在用到的地方添加,就是組件創(chuàng)建的時(shí)候。

附上組件js全部代碼:

?
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
const app = getApp()
Component({
  properties: {
 
  },
  data: {
    red_heart:0
  },
  lifetimes:{
    attached(){
      let watch = {
        id:this.__wxExparserNodeId__,
        update:()=>{
          this.setData({
            red_heart:app.globalData.red_heart
          })
        }
      }
      app.globalDep.RedHeartDep.addSub(watch)
      app.globalData.red_heart = app.globalData.red_heart
    },
    detached(){
      app.globalDep.RedHeartDep.removeWatch(this.__wxExparserNodeId__)
    }
  },
  methods: {
    handClick(){
      app.globalData.red_heart++
      console.log(app.globalData)
    }
  }
})

在attached上添加依賴,在組件銷毀的時(shí)候也不要忘記把依賴刪除,這個(gè)id是小程序的一個(gè)編譯id,直接拿來用了。
害就這樣了就做好啦!

總結(jié)

到此這篇關(guān)于微信小程序如何監(jiān)聽全局變量的文章就介紹到這了,更多相關(guān)小程序監(jiān)聽全局內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://juejin.cn/post/6942319891911278599

延伸 · 閱讀

精彩推薦
  • js教程uniapp微信小程序:key失效的解決方法

    uniapp微信小程序:key失效的解決方法

    這篇文章主要介紹了uniapp微信小程序:key失效的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友...

    灬都是個(gè)謎11142022-01-05
  • js教程詳解js創(chuàng)建對(duì)象的幾種方式和對(duì)象方法

    詳解js創(chuàng)建對(duì)象的幾種方式和對(duì)象方法

    這篇文章主要介紹了詳解js創(chuàng)建對(duì)象的幾種方式和對(duì)象方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的...

    joychenke3782022-01-24
  • js教程JavaScript/TypeScript 實(shí)現(xiàn)并發(fā)請(qǐng)求控制的示例代碼

    JavaScript/TypeScript 實(shí)現(xiàn)并發(fā)請(qǐng)求控制的示例代碼

    這篇文章主要介紹了JavaScript/TypeScript 實(shí)現(xiàn)并發(fā)請(qǐng)求控制,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友...

    鳳晴鈴玉3992022-01-04
  • js教程JavaScript數(shù)據(jù)結(jié)構(gòu)之雙向鏈表

    JavaScript數(shù)據(jù)結(jié)構(gòu)之雙向鏈表

    這篇文章主要為大家詳細(xì)介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)之雙向鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    希魔王的塔羅牌7882022-02-13
  • js教程利用JS判斷元素是否為數(shù)組的方法示例

    利用JS判斷元素是否為數(shù)組的方法示例

    這篇文章主要給大家介紹了關(guān)于利用JS判斷元素是否為數(shù)組的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)...

    Fahrenheitzz10072021-12-29
  • js教程原生Js實(shí)現(xiàn)日歷掛件

    原生Js實(shí)現(xiàn)日歷掛件

    這篇文章主要為大家詳細(xì)介紹了原生Js實(shí)現(xiàn)日歷掛件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    清靜清源11962022-02-17
  • js教程js實(shí)現(xiàn)簡(jiǎn)單放大鏡特效

    js實(shí)現(xiàn)簡(jiǎn)單放大鏡特效

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)簡(jiǎn)單放大鏡特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    一個(gè)21歲的老同志9592022-02-13
  • js教程js實(shí)現(xiàn)鼠標(biāo)切換圖片(無定時(shí)器)

    js實(shí)現(xiàn)鼠標(biāo)切換圖片(無定時(shí)器)

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)鼠標(biāo)切換圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下...

    楓思然8172022-01-10
主站蜘蛛池模板: 精品国产一二区 | 久久久久成人免费 | 黄色高清免费 | 成人一级片毛片 | 性生活视频软件 | 午夜视频在线 | 日本在线观看高清完整版 | 免费1级做55爰片l在线观看 | 美女视频免费一区二区 | 草碰人人| 亚洲射吧| 久久久久久久久浪潮精品 | 国产免费高清在线 | xnxx 日本免费 | 国产片91 | 欧美xxxxx视频 | 日韩欧美动作影片 | 成人短视频在线播放 | 精国品产一区二区三区有限公司 | 九色中文字幕 | 国产精品成人av片免费看最爱 | 国产69精品久久久久9999不卡免费 | 中文字幕一二区 | 国产午夜免费视频 | 红杏网站永久免费视频入口 | 日美av在线 | 国产精品久久亚洲 | 免看黄大片aa | 中文字幕一区2区 | 亚洲日本韩国在线观看 | 欧美精品电影一区二区 | 99视频网| 国产精品久久久久久影院8一贰佰 | 国产精品国产三级国产aⅴ无密码 | 免费黄色a | 久久96国产精品久久秘臀 | 久久艹综合 | 久久精品电影网 | 久久老司机 | 国产一区二区久久精品 | 黄色电影免费提供 |