日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue使用mixins優(yōu)化組件

瀏覽:26日期:2022-09-30 11:27:53

vue 提供了 mixins 這個 API,可以讓我們將組件中的可復(fù)用功能抽取出來,放入 mixin 中,然后在組件中引入 mixin,可以讓組件顯得不再臃腫,提高了代碼的可復(fù)用性。

如何理解 mixins 呢 ?我們可以將 mixins 理解成一個數(shù)組,數(shù)組中有單或多個 mixin,mixin 的本質(zhì)就是一個 JS 對象,它可以有 data、created、methods 等等 vue 實例中擁有的所有屬性,甚至可以在 mixins 中再次嵌套 mixins,It’s amazing !

舉個簡單的栗子:

<div id='app'> <h1>{{ message }}</h1></div>

const myMixin = { data() { return { message: ’this is mixin message’ } }, created() { console.log(’mixin created’) }}const vm = new Vue({ el: ’#app’, mixins: [myMixin], data() { return { message: ’this is vue instance message’ } }, created() { console.log(this.message) // => Root Vue Instance console.log(’vue instance created’) // => created myMixin // => created Root Vue Instance }})

mixins 與 Vue Instance 合并時,會將 created 等鉤子函數(shù)合并成數(shù)組,mixins 的鉤子優(yōu)先調(diào)用,當(dāng) data、methods 對象鍵值沖突時,以組件優(yōu)先。

PS: 如果對 mixins 的概念還不太清的小伙伴,可以去 vue 官方文檔 看一下 vue mixins 的基本概念和用法。

mixins 實現(xiàn)

那 mixins 是如何實現(xiàn)的呢 ?當(dāng) vue 在實例化的時候,會調(diào)用 mergeOptions 函數(shù)進(jìn)行 options 的合并,函數(shù)申明在 vue/src/core/util/options.js 文件。

export function mergeOptions( parent: Object, child: Object, vm?: Component): Object { ... // 如果有 child.extends 遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝 const extendsFrom = child.extends if (extendsFrom) { parent = mergeOptions(parent, extendsFrom, vm) } // 如果有 child.mixins 遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝 if (child.mixins) { for (let i = 0, l = child.mixins.length; i < l; i++) { parent = mergeOptions(parent, child.mixins[i], vm) } } // 申明 options 空對象,用來保存屬性拷貝結(jié)果 const options = {} let key // 遍歷 parent 對象,調(diào)用 mergeField 進(jìn)行屬性拷貝 for (key in parent) { mergeField(key) } // 遍歷 parent 對象,調(diào)用 mergeField 進(jìn)行屬性拷貝 for (key in child) { if (!hasOwn(parent, key)) { mergeField(key) } } // 屬性拷貝實現(xiàn)方法 function mergeField(key) { // 穿透賦值,默認(rèn)為 defaultStrat const strat = strats[key] || defaultStrat options[key] = strat(parent[key], child[key], vm, key) } return options}

為了保持代碼簡潔,已經(jīng)將 mergeOptions 函數(shù)不重要的代碼刪除,剩余部分我們慢慢來看。

const extendsFrom = child.extendsif (extendsFrom) { parent = mergeOptions(parent, extendsFrom, vm)}

首先申明 extendsFrom 變量保存 child.extends,如果 extendsFrom 為真,遞歸調(diào)用 mergeOptions 進(jìn)行屬性拷貝,并且將 merge 結(jié)果保存到 parent 變量。

if (child.mixins) { for (let i = 0, l = child.mixins.length; i < l; i++) { parent = mergeOptions(parent, child.mixins[i], vm) }}

如果 child.mixins 為真,循環(huán) mixins 數(shù)組,遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝,仍舊將 merge 結(jié)果保存到 parent 變量。

接下來是關(guān)于 parent、child 的屬性賦值:

const options = {}let keyfor (key in parent) { mergeField(key)}for (key in child) { if (!hasOwn(parent, key)) { mergeField(key) }}

申明 options 空對象,用來保存屬性拷貝的結(jié)果,也作為遞歸調(diào)用 mergeOptions 的返回值。

這里首先會調(diào)用 for...in 對 parent 進(jìn)行循環(huán),在循環(huán)中不斷調(diào)用 mergeField 函數(shù)。

接著調(diào)用 for...in 對 child 進(jìn)行循環(huán),這里有點不太一樣,會調(diào)用 hasOwn 判斷 parent 上是否有這個 key,如果沒有再調(diào)用 mergeField 函數(shù),這樣避免了重復(fù)調(diào)用。

那么這個 mergeField 函數(shù)到底是用來做什么的呢?

function mergeField(key) { // 穿透賦值,默認(rèn)為 defaultStrat const strat = strats[key] || defaultStrat options[key] = strat(parent[key], child[key], vm, key)}

mergeField 函數(shù)接收一個 key,首先會申明 strat 變量,如果 strats[key] 為真,就將 strats[key] 賦值給 strat。

const strats = config.optionMergeStrategies...optionMergeStrategies: Object.create(null),...

strats 其實就是 Object.create(null),Object.create 用來創(chuàng)建一個新對象,strats 默認(rèn)是調(diào)用 Object.create(null) 生成的空對象。

順便說一句,vue 也向外暴露了 Vue.config.optionMergeStrategies,可以實現(xiàn)自定義選項合并策略。

如果 strats[key] 為假,這里會用 || 做穿透賦值,將 defaultStrat 默認(rèn)函數(shù)賦值給 strat。

const defaultStrat = function(parentVal: any, childVal: any): any { return childVal === undefined ? parentVal : childVal}

defaultStrat 函數(shù)返回一個三元表達(dá)式,如果 childVal 為 undefined,返回 parentVal,否則返回 childVal,這里主要以 childVal 優(yōu)先,這也是為什么有 component > mixins > extends 這樣的優(yōu)先級。

mergeField 函數(shù)最后會將調(diào)用 strat 的結(jié)果賦值給 options[key]。

mergeOptions 函數(shù)最后會 merge 所有 options、 mixins、 extends,并將 options 對象返回,然后再去實例化 vue。

鉤子函數(shù)的合并

我們來看看鉤子函數(shù)是怎么進(jìn)行合并的。

function mergeHook( parentVal: ?Array<Function>, childVal: ?Function | ?Array<Function>): ?Array<Function> { return childVal ? parentVal ? parentVal.concat(childVal) : Array.isArray(childVal) ? childVal : [childVal] : parentVal}LIFECYCLE_HOOKS.forEach(hook => { strats[hook] = mergeHook})

循環(huán) LIFECYCLE_HOOKS 數(shù)組,不斷調(diào)用 mergeHook 函數(shù),將返回值賦值給 strats[hook]。

export const LIFECYCLE_HOOKS = [ ’beforeCreate’, ’created’, ’beforeMount’, ’mounted’, ’beforeUpdate’, ’updated’, ’beforeDestroy’, ’destroyed’, ’activated’, ’deactivated’, ’errorCaptured’]

LIFECYCLE_HOOKS 就是申明的 vue 所有的鉤子函數(shù)字符串。

mergeHook 函數(shù)會返回 3 層嵌套的三元表達(dá)式。

return childVal ? parentVal ? parentVal.concat(childVal) : Array.isArray(childVal) ? childVal : [childVal] : parentVal

第一層,如果 childVal 為真,返回第二層三元表達(dá)式,如果為假,返回 parentVal。

第二層,如果 parentVal 為真,返回 parentVal 和 childVal 合并后的數(shù)組,如果 parentVal 為假,返回第三層三元表達(dá)式。

第三層,如果 childVal 是數(shù)組,返回 childVal,否則將 childVal 包裝成數(shù)組返回。

new Vue({ created: [ function() { console.log(’沖沖沖!’) }, function() { console.log(’鴨鴨鴨!’) } ]})// => 沖沖沖!// => 鴨鴨鴨!項目實踐

使用 vue 的小伙伴們,當(dāng)然也少不了在項目中使用 element-ui。比如使用 Table 表格的時候,免不了申明 tableData、total、pageSize 一些 Table 表格、Pagination 分頁需要的參數(shù)。

我們可以將重復(fù)的 data、methods 寫在一個 tableMixin 中。

export default { data() { return { total: 0, pageNo: 1, pageSize: 10, tableData: [], loading: false } }, created() { this.searchData() }, methods: { // 預(yù)申明,防止報錯 searchData() {}, handleSizeChange(size) { this.pageSize = size this.searchData() }, handleCurrentChange(page) { this.pageNo = page this.searchData() }, handleSearchData() { this.pageNo = 1 this.searchData() } }}

當(dāng)我們需要使用時直接引入即可:

import tableMixin from ’./tableMixin’export default { ... mixins: [tableMixin], methods: { searchData() { ... } }}

我們在組件內(nèi)會重新申明 searchData 方法。類似這種 methods 對象形式的 key,如果 key 相同,組件內(nèi)的 key 會覆蓋 tableMixin 中的 key。

當(dāng)然我們也可以在 mixins 中嵌套 mixins,申明 axiosMixin:

import tableMixin from ’./tableMixin’export default { mixins: [tableMixin], methods: { handleFetch(url) { const { pageNo, pageSize } = this this.loading = true this.axios({method: ’post’,url,data: { ...this.params, pageNo, pageSize} }).then(({ data = [] }) => { this.tableData = data this.loading = false}).catch(error => { this.loading = false}) } }}

引入 axiosMixin:

import axiosMixin from ’./axiosMixin’export default { ... mixins: [axiosMixin], created() { this.handleFetch(’/user/12345’) }}

在 axios 中,我們可以預(yù)先處理 axios 的 success、error 的后續(xù)調(diào)用,是不是少寫了很多代碼。

extend

順便講一下 extend,與 mixins 相似,只能傳入一個 options 對象,并且 mixins 的優(yōu)先級比較高,會覆蓋 extend 同名 key 值。

// 如果有 child.extends 遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝const extendsFrom = child.extendsif (extendsFrom) { parent = mergeOptions(parent, extendsFrom, vm)}// 如果有 child.mixins 遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝if (child.mixins) { for (let i = 0, l = child.mixins.length; i < l; i++) { parent = mergeOptions(parent, child.mixins[i], vm) }}

// 如果有 child.extends 遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝const extendsFrom = child.extendsif (extendsFrom) { parent = mergeOptions(parent, extendsFrom, vm)}// 如果有 child.mixins 遞歸調(diào)用 mergeOptions 實現(xiàn)屬性拷貝if (child.mixins) { for (let i = 0, l = child.mixins.length; i < l; i++) { parent = mergeOptions(parent, child.mixins[i], vm) }}

在 mergeOptions 函數(shù)中,會先對 extends 進(jìn)行屬性拷貝,然后再對 mixin 進(jìn)行拷貝,在調(diào)用 mergeField 函數(shù)的時候會優(yōu)先取 child 的 key。

雖然 extends 的同名 key 會被 mixins 的覆蓋,但是 extends 是優(yōu)先執(zhí)行的。

總結(jié)

注意一下 vue 中 mixins 的優(yōu)先級,component > mixins > extends。

我們暫且將 mixins 稱作是組件模塊化,靈活運用組件模塊化,可以將組件內(nèi)的重復(fù)代碼提取出來,實現(xiàn)代碼復(fù)用,也使我們的代碼更加清晰,效率也大大提高。

當(dāng)然,mixins 還有更加神奇的操作等你去探索。

以上就是vue使用mixins優(yōu)化組件的詳細(xì)內(nèi)容,更多關(guān)于vue 用mixins優(yōu)化組件的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本va欧美va瓶| 精品国产美女a久久9999| 久久久久久久欧美精品| 欧美中文一区| 国产精品视频3p| 欧美一区激情| 91日韩欧美| 亚洲一级高清| 亚洲一区成人| 亚洲精品国产偷自在线观看| 91精品一区二区三区综合在线爱| 波多野结衣久久精品| 美女毛片一区二区三区四区| 欧美另类综合| 日本亚洲不卡| 欧美国产中文高清| 91亚洲一区| 蜜臀久久99精品久久久久宅男| 免费中文字幕日韩欧美| 亚洲精品系列| 国产精品a久久久久| 99久久99久久精品国产片果冰| 美女国产精品| 麻豆国产精品一区二区三区| 亚洲天堂免费电影| 蜜桃久久精品一区二区| 精品视频亚洲| 另类亚洲自拍| 精品久久中文| 亚洲1区在线观看| 人人精品亚洲| 久久99免费视频| 蜜桃视频一区二区| 四虎4545www国产精品 | 亚洲字幕久久| 97在线精品| 久久精品999| 亚洲综合日韩| 91嫩草亚洲精品| 欧美日本二区| 日本v片在线高清不卡在线观看| 欧美日韩色图| av免费不卡国产观看| 国产日韩免费| 国产亚洲一区| 日韩成人一级| 日韩精品五月天| 中文字幕乱码亚洲无线精品一区| 欧美日韩国产综合网| 欧美13videosex性极品| 日韩欧美在线精品| 综合欧美亚洲| 综合一区二区三区| 久久亚洲风情| 久久福利精品| 亚洲小说春色综合另类电影| 免费日韩一区二区| 在线国产精品一区| 亚洲日本久久| 日本aⅴ免费视频一区二区三区| 亚洲精品乱码久久久久久蜜桃麻豆| 国产精品嫩草99av在线| 一区三区视频| 久久高清免费观看| 视频一区日韩| 一区二区亚洲视频| 日韩欧美中文字幕电影| 国产精品久久久久毛片大屁完整版| 国产精品亚洲产品| 国产一区一一区高清不卡| 岛国av免费在线观看| 99久久亚洲精品| 免费在线观看一区二区三区| 日本麻豆一区二区三区视频| 国产精品手机在线播放| 91综合网人人| 免费观看在线综合色| 国产亚洲久久| 日韩啪啪电影网| 久久福利毛片| 国产精品亚洲欧美一级在线 | 欧美一区自拍| 色综合狠狠操| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产探花一区| 亚洲韩日在线| 国产精品igao视频网网址不卡日韩 | 国产农村妇女精品一二区| 国产日韩欧美中文在线| 日韩欧美精品一区| 综合激情网站| 91tv亚洲精品香蕉国产一区| 91精品麻豆| 国产精品88久久久久久| 国产毛片一区二区三区| 黄色不卡一区| 久久久久九九精品影院| 午夜一级在线看亚洲| 日本欧美国产| 欧美日韩1区2区3区| 99国产一区| 成人小电影网站| 国产日韩综合| 99pao成人国产永久免费视频 | 国产一区导航| 福利欧美精品在线| 日本精品一区二区三区在线观看视频| 免费高潮视频95在线观看网站| 欧美午夜三级| 亚洲伊人影院| 女主播福利一区| 色婷婷色综合| 国产日韩欧美高清免费| 视频一区视频二区在线观看| 欧美~级网站不卡| 日韩在线观看不卡| 色88888久久久久久影院| 黄色网一区二区| 精品国产亚洲日本| 国内揄拍国内精品久久| 精品久久久久中文字幕小说| 久久久亚洲欧洲日产| 国产精品久久久久久av公交车 | 成人自拍av| 国产精选在线| 日韩在线不卡| 久久精品青草| 亚洲欧美综合| 国产毛片精品| 久久一区精品| а√天堂8资源中文在线| www.com.cn成人| 国产一区亚洲| 免费观看在线综合| 国产精品久久久久av蜜臀| 精品免费视频| 欧美丝袜一区| 亚洲性视频在线| 国产乱码精品一区二区亚洲| 国产欧美日韩精品一区二区免费| 国产精品一级| 高清一区二区| 黄色精品网站| 国产欧美日韩综合一区在线播放| 红杏一区二区三区| 一区二区亚洲精品| 国产图片一区| 日韩高清中文字幕一区二区| 男人的天堂久久精品| 牛牛精品成人免费视频| 久久精品影视| 国产图片一区| 黄色亚洲精品| 国产一区一一区高清不卡| 欧美日韩中文字幕一区二区三区| 国产精品视区| 日本中文字幕不卡| 国产99久久| 国产精品欧美日韩一区| 不卡中文字幕| 国产一区二区三区四区| 视频一区二区三区在线| www.九色在线| 青青草国产成人99久久| 1024精品久久久久久久久| 久久精品一区二区国产| 蜜臀va亚洲va欧美va天堂 | 久久影视一区| 久久久亚洲欧洲日产| 日本欧洲一区二区| jiujiure精品视频播放| 水蜜桃久久夜色精品一区| 国产日韩欧美一区二区三区| 美女久久一区| 欧美特黄一级大片| 久久男人av资源站| 免费看久久久| 欧美日韩亚洲一区二区三区在线| 99riav国产精品| 香蕉精品视频在线观看| 群体交乱之放荡娇妻一区二区| 麻豆精品av| 婷婷久久免费视频| 亚洲精品九九| 免播放器亚洲一区| 石原莉奈一区二区三区在线观看| 欧美va亚洲va日韩∨a综合色| 黑森林国产精品av| 欧美gv在线| 91精品福利| 中日韩男男gay无套| 国产婷婷精品| 蜜臀国产一区二区三区在线播放| 国产偷自视频区视频一区二区| 伊人影院久久| 在线看片日韩| 欧美日韩视频免费看| 欧美日韩中出| 成人在线免费观看网站| 色一区二区三区|