vue中使用mixins/extends傳入?yún)?shù)的方式
使用mixins/extends傳入?yún)?shù)
最近做報(bào)表頁面,基本都是列表頁面,所以想用mixins。
但是接口的url不同,于是考慮怎么才能傳入?yún)?shù)去適配各個(gè)頁面。
后來發(fā)現(xiàn)mixin文件可以寫個(gè)函數(shù),接受傳遞過來的參數(shù),然后return一個(gè)對象。
大概如下:
mixin.js
export default function(config) {
? ? let {
? ? ? ? listUrl="",
? ? ? ? exportUrl=""
? ? } = config;
? ? return {
? ? ? ? created() {
? ? ? ? ? ? console.log(listUrl);
? ? ? ? ? ? console.log(exportUrl);
? ? ? ? }
? ? }
}xxx.vue
import Mixin from './mixin';
let mixin = new Mixin({
? ? listUrl: "www.baidu.com",
? ? exportUrl: "www.yahu.com"
})
?
export default{
? ? mixins:[mixin],
}extends也是差不多。
vue mixins的原理
以前一直以為mixins在vue里面應(yīng)該不是很重要,只是提供了一個(gè)混入的api,慢慢的才知道m(xù)ixin在vue里面非常重要。生命周期、vuex等都有mixin的影子,在內(nèi)部算是很重要的一個(gè)api。
先上精簡過后的源碼:
export const LIFECYCLE_HOOKS = [
? ? 'beforeCreate',
? ? 'created',
? ? 'beforeMount',
? ? 'mounted',
? ? 'beforeUpdate',
? ? 'updated',
? ? 'beforeDestroy',
? ? 'destroyed',
]
const strats = {};
function mergeHook(parentVal, childValue) {
? ? if (childValue) {
? ? ? ? if (parentVal) {
? ? ? ? ? ? return parentVal.concat(childValue);
? ? ? ? } else {
? ? ? ? ? ? return [childValue]
? ? ? ? }
? ? } else {
? ? ? ? return parentVal;
? ? }
}
LIFECYCLE_HOOKS.forEach(hook => {
? ? strats[hook] = mergeHook
})上面這部分很好理解,是生命周期的合并,下面判斷有這些生命周期的key的時(shí)候,直接調(diào)用strats[key](parent[key], child[key]),我們都知道生命周期的mixins是先執(zhí)行mixins的再執(zhí)行當(dāng)前組件的,所以直接concat,后面執(zhí)行循環(huán)調(diào)用的時(shí)候就是這個(gè)順序。
export function mergeOptions(parent, child) {
? ? const options = {}
? ? if (child.mixins) {
? ? ? ? for (var i = 0, l = child.mixins.length; i < l; i++) {
? ? ? ? ? ? var mixin = child.mixins[i];
? ? ? ? ? ? parent = mergeOptions(parent, mixin);
? ? ? ? }
? ? }
? ? for (let key in parent) {
? ? ? ? mergeField(key)
? ? }
? ? for (let key in child) {
? ? ? ? if (!parent.hasOwnProperty(key)) {
? ? ? ? ? ? mergeField(key);
? ? ? ? }
? ? }
? ? function mergeField(key) {
? ? ? ? if (strats[key]) {
? ? ? ? ? ? options[key] = strats[key](parent[key], child[key]);
? ? ? ? } else {
? ? ? ? ? ? if (typeof parent[key] == 'object' && typeof child[key] == 'object') {
? ? ? ? ? ? ? ? options[key] = {
? ? ? ? ? ? ? ? ? ? ...parent[key],
? ? ? ? ? ? ? ? ? ? ...child[key]
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? options[key] = child[key];
? ? ? ? ? ? }
? ? ? ? }
? ? }
? ? return options
}這邊生命周期是單獨(dú)判斷,其他熟悉方法則是一起的,比如方法methods,如果父和子都有,就結(jié)構(gòu)合并在一起。因?yàn)閙ixins用法可以傳入一個(gè)數(shù)組,這邊還需要優(yōu)先判斷是否有mixins字段,有就要遞歸合并。
核心有了其他都是調(diào)用了,比如把mixin方法掛載到vue上可以直接調(diào)用:
Vue.mixin = function (mixin) {
? ? // 將屬性合并到Vue.options上
? ? this.options = mergeOptions(this.options,mixin);
? ? return this;
}初始化的時(shí)候先合并一次,生命周期也是,在狀態(tài)初始化之前先調(diào)用beforeCreate,初始化之后調(diào)用created,源碼搜索Vue.prototype._init這個(gè)方法里面就能看見,包括其他生命周期,可以搜索callhook去看看:
vm.$options = mergeOptions(vm.constructor.options,options); callHook(vm,'beforeCreate');
// 初始化狀態(tài)
initState(vm); callHook(vm,'created');
callHook就是循環(huán)調(diào)用生命周期:
export function callHook(vm, hook) {
? ? const handlers = vm.$options[hook];
? ? if (handlers) {
? ? ? ? for (let i = 0; i < handlers.length; i++) {
? ? ? ? ? ? handlers[i].call(vm);
? ? ? ? }
? ? }
}mixin方法核心就是合并實(shí)例的屬性,watch、methods、data等,也可以新增一開始沒有的屬性,比如vuex的$store。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue3響應(yīng)式Proxy與Reflect的理解及基本使用實(shí)例詳解
這篇文章主要為大家介紹了vue3響應(yīng)式Proxy與Reflect的理解及基本使用實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Vue3+elementui plus創(chuàng)建項(xiàng)目的方法
這篇文章主要介紹了Vue3+elementui plus創(chuàng)建項(xiàng)目的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
vue中實(shí)現(xiàn)點(diǎn)擊空白區(qū)域關(guān)閉彈窗的兩種方法
這篇文章主要介紹了vue中實(shí)現(xiàn)點(diǎn)擊空白區(qū)域關(guān)閉彈窗的兩種方法,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2020-12-12
vue使用axios獲取不到響應(yīng)頭Content-Disposition的問題及解決
這篇文章主要介紹了vue使用axios獲取不到響應(yīng)頭Content-Disposition的問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
解決VUE-npm ERR! C:\rj\node-v14.4.0-win-x64\nod問題
這篇文章主要介紹了解決VUE-npm ERR! C:\rj\node-v14.4.0-win-x64\nod問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04
vue結(jié)合vant實(shí)現(xiàn)聯(lián)動效果
這篇文章主要為大家詳細(xì)介紹了vue結(jié)合vant實(shí)現(xiàn)聯(lián)動效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
vue的圖片需要用require的方式進(jìn)行引入問題
這篇文章主要介紹了vue的圖片需要用require的方式進(jìn)行引入問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03

