亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

如何在微信小程序中實現Mixins方案

2024-05-06 16:52:28
字體:
來源:轉載
供稿:網友

前言

在原生開發小程序的過程中,發現有多個頁面都使用了幾乎完全一樣的邏輯。由于小程序官方并沒有提供 Mixins 這種代碼復用機制,所以只能采用非常不優雅的復制粘貼的方式去“復用”代碼。隨著功能越來越復雜,靠復制粘貼來維護代碼顯然不科學,于是便尋思著如何在小程序里面實現 Mixins。

什么是 Mixins

Mixins 直譯過來是“混入”的意思,顧名思義就是把可復用的代碼混入當前的代碼里面。熟悉 VueJS 的同學應該清楚,它提供了更強大了代碼復用能力,解耦了重復的模塊,讓系統維護更加方便優雅。

先看看在 VueJS 中是怎么使用 Mixins 的。

// define a mixin objectvar myMixin = { created: function () { this.hello() }, methods: { hello: function () {  console.log('hello from mixin!') } }}// define a component that uses this mixinvar Component = Vue.extend({ mixins: [myMixin]})var component = new Component() // => "hello from mixin!"

在上述的代碼中,首先定義了一個名為 myMixin 的對象,里面定義了一些生命周期函數和方法。接著在一個新建的組件里面直接通過 mixins: [myMixin] 的方式注入,此時新建的組件便獲得了來自 myMixin 的方法了。

明白了什么是 Mixins 以后,便可開始著手在小程序里面實現了。

Mixins 的機制

Mixins 也有一些小小的細節需要注意的,就是關于生命周期事件的執行順序。在上一節的例子中,我們在 myMixin 里定義了一個 created() 方法,這是 VueJS 里面的一個生命周期事件。如果我們在新建組件 Component 里面也定義一個 created() 方法,那么執行結果會是如何呢?

var Component = Vue.extend({ mixins: [myMixin], created: function () { console.log('hello from Component!') }})var component = new Component()// =>// Hello from mixin!// Hello from Component!

可以看運行結果是先輸出了來自 Mixin 的 log,再輸出來自組件的 log。

除了生命周期函數以外,再看看對象屬性的混入結果:

// define a mixin objectconst myMixin = { data () { return {  mixinData: 'data from mixin' } }}// define a component that uses this mixinvar Component = Vue.extend({ mixins: [myMixin], data () { return {  componentData: 'data from component' } }, mounted () { console.log(this.$data) }})var component = new Component()

微信小程序,Mixins

在 VueJS 中,會把來自 Mixins 和組件的對象屬性當中的內容(如 data, methods等)混合,以確保兩邊的數據都同時存在。

經過上述的驗證,我們可以得到 VueJS 中關于 Mixins 運行機制的結論:

  • 生命周期屬性,會優先執行來自 Mixins 當中的,后執行來自組件當中的。
  • 對象類型屬性,來自 Mixins 和來自組件中的會共存。

但是在小程序中,這套機制會和 VueJS 的有一點區別。在小程序中,自定義的方法是直接定義在 Page 的屬性當中的,既不屬于生命周期類型屬性,也不屬于對象類型屬性。為了不引入奇怪的問題,我們為小程序的 Mixins 運行機制多加一條:

  • 小程序中的自定義方法,優先級為 Page > Mixins,即 Page 中的自定義方法會覆蓋 Mixins 當中的。

代碼實現

在小程序中,每個頁面都由 Page(options) 函數定義,而 Mixins 則作用于這個函數當中的 options 對象。因此我們實現 Mixins 的思路就有了——劫持并改寫 Page 函數,最后再重新把它釋放出來。

新建一個 mixins.js 文件:

// 保存原生的 Page 函數const originPage = PagePage = (options) => { const mixins = options.mixins // mixins 必須為數組 if (Array.isArray(mixins)) { delete options.mixins // mixins 注入并執行相應邏輯 merge(mixins, options) } // 釋放原生 Page 函數 originPage(options)}

原理很簡單,關鍵的地方在于 merge() 函數。merge 函數即為小程序 Mixins 運行機制的具體實現,完全按照上一節總結的三條結論來進行。

// 定義小程序內置的屬性/方法const originProperties = ['data', 'properties', 'options']const originMethods = ['onLoad', 'onReady', 'onShow', 'onHide', 'onUnload', 'onPullDownRefresh', 'onReachBottom', 'onShareAppMessage', 'onPageScroll', 'onTabItemTap']function merge (mixins, options) { mixins.forEach((mixin) => { if (Object.prototype.toString.call(mixin) !== '[object Object]') {  throw new Error('mixin 類型必須為對象!') } // 遍歷 mixin 里面的所有屬性 for (let [key, value] of Object.entries(mixin)) {  if (originProperties.includes(key)) {  // 內置對象屬性混入  options[key] = { ...value, ...options[key] }  } else if (originMethods.includes(key)) {  // 內置方法屬性混入,優先執行混入的部分  const originFunc = options[key]  options[key] = function (...args) {   value.call(this, ...args)   return originFunc && originFunc.call(this, ...args)  }  } else {  // 自定義方法混入  options = { ...mixin, ...options }  } } })}

Mixins 使用

在小程序的 app.js 里引入 mixins.js

require('./mixins.js')

撰寫一個 myMixin.js

module.exports = { data: { someData: 'myMixin' }, onShow () { console.log('Log from mixin!') }}

在 page/index/index.js 中使用

Page({ mixins: [require('../../myMixin.js')]})

微信小程序,Mixins

大功告成!此時小程序已經具備 Mixins 的能力,對于代碼解耦與復用來說將會更加方便。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产99久久精品一区二区永久免费| 伊人久久免费视频| 国产精品精品久久久| 亚洲自拍在线观看| 亚洲午夜久久久影院| 成人精品在线视频| 亚洲国产精品嫩草影院久久| 亚洲欧美精品伊人久久| 亚洲在线第一页| 热门国产精品亚洲第一区在线| 精品国产依人香蕉在线精品| 国产精品旅馆在线| 日韩在线免费观看视频| 国产免费观看久久黄| 色悠悠久久88| 欧美成人精品在线观看| 国产激情综合五月久久| 日韩av在线看| 久久亚洲精品国产亚洲老地址| 日韩有码在线电影| 日本精品免费一区二区三区| 亚洲综合日韩中文字幕v在线| 一区二区在线视频播放| 91久久国产综合久久91精品网站| 日韩亚洲一区二区| 久久av.com| 欧美人与物videos| 成人国内精品久久久久一区| 日韩精品在线影院| 欧美在线视频免费| 国产香蕉一区二区三区在线视频| 午夜精品久久久久久久男人的天堂| 最新中文字幕亚洲| 亚洲欧美制服中文字幕| 国产成人在线精品| 国产精品久久77777| 欧美激情网站在线观看| 91精品久久久久久久久久| 欧美激情国产日韩精品一区18| 日韩电影免费观看中文字幕| 激情成人在线视频| www.亚洲男人天堂| 国产精品视频网站| 综合国产在线视频| 国产亚洲欧美日韩一区二区| 国产精品久久久亚洲| 亚洲欧美在线一区| 动漫精品一区二区| 欧美激情va永久在线播放| 日韩av一区二区在线| 精品亚洲va在线va天堂资源站| 欧美视频在线免费| 菠萝蜜影院一区二区免费| 九九热最新视频//这里只有精品| 国产精品劲爆视频| 欧美电影在线免费观看网站| 日韩在线视频中文字幕| 日本精品中文字幕| 欧美黑人xxxx| 一本色道久久88亚洲综合88| 伊人男人综合视频网| 精品调教chinesegay| 国产精品福利在线| 日韩欧美在线字幕| 久久久www成人免费精品张筱雨| 国产精品久久久久久一区二区| 91chinesevideo永久地址| 国产午夜精品一区理论片飘花| 久久综合久中文字幕青草| 国产精品免费久久久久久| 久久五月天综合| 国产精品99久久久久久www| 精品国产欧美成人夜夜嗨| 日本精品久久中文字幕佐佐木| 欧美精品激情视频| 亚洲丝袜一区在线| 欧美性高跟鞋xxxxhd| 欧美裸身视频免费观看| 国产成人精品视频在线| 亚洲国产精品va在线观看黑人| 日本精品久久久久影院| 精品福利在线看| 久久久久久久网站| 欧美激情一区二区久久久| 久久精品久久久久久国产 免费| 欧美老少做受xxxx高潮| 久久精品国产欧美激情| 国产一区二区av| 国产精品第3页| 91九色国产在线| 日韩在线视频二区| 亚洲码在线观看| 久久久精品国产亚洲| 国产99在线|中文| 亚洲精品在线观看www| 在线播放国产一区二区三区| 国产免费成人av| 日韩av理论片| 日韩亚洲精品视频| 欧美日本国产在线| 欧美日韩亚洲激情| 成人情趣片在线观看免费| 97视频在线观看亚洲| 午夜精品一区二区三区在线| 九九热r在线视频精品| 一级做a爰片久久毛片美女图片| 日韩电视剧在线观看免费网站| 92版电视剧仙鹤神针在线观看| 综合国产在线观看| 成人av番号网| 欧美日韩国产在线看| 欧美成人精品在线播放| 欧美激情影音先锋| 久久夜精品va视频免费观看| 欧美电影在线免费观看网站| 久久综合久久美利坚合众国| 欧美在线视频播放| 国产亚洲精品va在线观看| 国产第一区电影| 久久久久久久久久久免费精品| 久久成人精品一区二区三区| 免费91麻豆精品国产自产在线观看| 国产91热爆ts人妖在线| 成人女保姆的销魂服务| 日韩av免费在线观看| 国产精品揄拍500视频| 国产视频精品一区二区三区| 九九热最新视频//这里只有精品| 国产精品国产三级国产专播精品人| 欧美在线观看网址综合| 国产91精品青草社区| 国产一区二区三区在线播放免费观看| 一区二区在线视频播放| 日韩免费av一区二区| 久久精品国产欧美亚洲人人爽| 久国内精品在线| 亚洲精品在线不卡| 欧美日韩另类视频| 成人激情视频在线观看| 国产成人在线精品| 亚洲国产精品中文| 亚洲第一福利网| 日韩精品高清在线观看| 亚洲a一级视频| 97激碰免费视频| 2021久久精品国产99国产精品| 九九热在线精品视频| 日本高清+成人网在线观看| 亚洲一品av免费观看| 国产精品久久久久久搜索| 亚洲免费视频网站| 亚洲国产精彩中文乱码av| 亚洲无限乱码一二三四麻| 久久欧美在线电影| 一本色道久久88亚洲综合88| 北条麻妃一区二区在线观看| 久久精品99久久久久久久久| 国产精品人人做人人爽| 国产91对白在线播放| 欧美视频中文字幕在线| 国产精品福利网站| 欧美在线视频免费观看| 欧美xxxx做受欧美| 8050国产精品久久久久久|