欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Vue 中 extend 、component 、mixins 、extends 的區(qū)別

 更新時(shí)間:2017年12月20日 09:37:58   作者:詩人的咸魚  
這篇文章主要介紹了Vue 中 extend 、component 、mixins 、extends 的區(qū)別,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

new Vue()、component

首先我們來約定一個(gè)選項(xiàng)對(duì)象 baseOptions,后面的代碼會(huì)用到.

let options = {
 template: '<p>{{firstName}} {{lastName}} aka {{alias}}</p>',
 data: function () {
  return {
   firstName: 'Walter',
   lastName: 'White',
   alias: 'Heisenberg'
  }
 },
 created(){
  console.log('onCreated-1');
 }
};

new Vue() source:vue/src/core/instance/index.js

實(shí)例化一個(gè)組件.

new Vue(baseOptions);
// -> onCreated-1
component source:vue/src/core/global-api/assets.js

Vue.component 是用來注冊(cè)或獲取全局組件的方法,其作用是將通過 Vue.extend 生成的擴(kuò)展實(shí)例構(gòu)造器注冊(cè)(命名)為一個(gè)組件.全局注冊(cè)的組件可以在所有晚于該組件注冊(cè)語句構(gòu)造的Vue實(shí)例中使用.

Vue.component('global-component', Vue.extend(baseOptions));
//傳入一個(gè)選項(xiàng)對(duì)象(自動(dòng)調(diào)用 Vue.extend),等價(jià)于上行代碼.
Vue.component('global-component', baseOptions);
// 獲取注冊(cè)的組件(始終返回構(gòu)造器)
var MyComponent = Vue.component('my-component')

當(dāng)我們需要在其他頁面‘?dāng)U展'或者叫‘混合'baseOptions時(shí),Vue中提供了多種的實(shí)現(xiàn)方式:extend,mixins,extends.

extend source:vue/src/core/global-api/extend.js

可以擴(kuò)展 Vue 構(gòu)造器,從而用預(yù)定義選項(xiàng)創(chuàng)建可復(fù)用的組件構(gòu)造器。

let BaseComponent = Vue.extend(baseOptions);
//基于基礎(chǔ)組件BaseComponent,再擴(kuò)展新邏輯.
new BaseComponent({
 created(){
  //do something
  console.log('onCreated-2');
 }
 //其他自定義邏輯
});
// -> onCreated-1
// -> onCreated-2

mixins

mixins 選項(xiàng)接受一個(gè)混合對(duì)象的數(shù)組。這些混合實(shí)例對(duì)象可以像正常的實(shí)例對(duì)象一樣包含選項(xiàng),他們將在 Vue.extend() 里最終選擇使用相同的選項(xiàng)合并邏輯合并。

new Vue({
 mixins: [baseOptions],
 created(){
  //do something
  console.log('onCreated-2');
 }
 //其他自定義邏輯
});
// -> onCreated-1
// -> onCreated-2

extends

這和 mixins 類似,區(qū)別在于,組件自身的選項(xiàng)會(huì)比要擴(kuò)展的源組件具有更高的優(yōu)先級(jí).

官方文檔是這么寫的,除了優(yōu)先級(jí),可能就剩下接受參數(shù)的類型吧,mixins接受的是數(shù)組.

new Vue({
 extends: baseOptions,
 created(){
  //do something
  console.log('onCreated-2');
 }
 //其他自定義邏輯
});
// -> onCreated-1
// -> onCreated-2

從結(jié)果上看,三種方式都能實(shí)現(xiàn)需求,但是形式卻有不同.

  • Vue.extend
  • Vue.extend只是創(chuàng)建一個(gè)構(gòu)造器,他是為了創(chuàng)建可復(fù)用的組件.
  • mixins,extends
  • 而mixins和extends是為了拓展組件.

從源碼來看通過extend,extends和mixins三種方式接收的options,最終都是通過mergeOptions進(jìn)行合并的.差異只是官方文檔中提到的優(yōu)先級(jí)不同extend > extends > mixins. 所以,如果是簡單的擴(kuò)展組件功能,三個(gè)方式都可以達(dá)到目的.

而這三種方式使用場(chǎng)景上細(xì)化的區(qū)分,目前我也蒙圈中...

//幾種方式的不同示例:

https://jsfiddle.net/willnewi...

選項(xiàng)對(duì)象合并策略 Vue.config.optionMergeStrategies

上面提到的選項(xiàng)對(duì)象,是在mergeOptions中按照一定策略進(jìn)行合并的.

打印Vue.config.optionMergeStrategies,你會(huì)看默認(rèn)的optionMergeStrategies如下:

  • mergeHook
  • 子組件和父組件的生命周期事件會(huì)合并在一個(gè)數(shù)組里。父組件在前,子組件在后。
  • watch
  • 子組件和父組件的watchers會(huì)合并在一個(gè)數(shù)組里。父組件在前,子組件在后。
  • mergeAssets(filters,components,directives)
  • 首先會(huì)在子組件里查找,如果沒有,才會(huì)沿著原型鏈向上,找父組件中對(duì)應(yīng)的屬性。
  • data 合并規(guī)則
  • 無重復(fù)的屬性保留
  • 同名覆蓋
  • data中的對(duì)象也是相同規(guī)則,無重復(fù)的屬性保留,同名覆蓋
  • props、methods、computed: 無重復(fù)保留,同名子組件覆蓋父組件

mergeAssets

mergeAssets合并方法里,用到了原型委托.他會(huì)先把父組件的屬性放在創(chuàng)建的新對(duì)象的原型鏈上.然后擴(kuò)展新對(duì)象

對(duì)象里查找屬性的規(guī)則 :舉個(gè)例子,當(dāng)查找一個(gè)屬性時(shí),如 obj[a] ,如果 obj 沒有 a 這個(gè)屬性,那么將會(huì)在 obj 對(duì)象的原型里找,如果還沒有,在原型的原型上找,直到原型鏈的盡頭,如果還沒有找到,返回 undefined。

function extend (to, _from) {
 for (var key in _from) {
 to[key] = _from[key];
 }
 return to
}
function mergeAssets (parentVal, childVal) {
 var res = Object.create(parentVal || null);
 return childVal
 ? extend(res, childVal)
 : res
}

總結(jié)

  • Vue.component 注冊(cè)全局組件,為了方便
  • Vue.extend 創(chuàng)建組件的構(gòu)造函數(shù),為了復(fù)用
  • mixins、extends 為了擴(kuò)展

如果按照優(yōu)先級(jí)去理解,當(dāng)你需要繼承一個(gè)組件時(shí),可以使用Vue.extend().當(dāng)你需要擴(kuò)展組件功能的時(shí)候,可以使用extends,mixins.但目前為止還沒有碰到完美詮釋他們的場(chǎng)景,抱歉,能力有限😂

相關(guān)文章

  • Vue+OpenLayer為地圖添加風(fēng)場(chǎng)效果

    Vue+OpenLayer為地圖添加風(fēng)場(chǎng)效果

    這篇文章主要為大家展示了一個(gè)demo,即利用Vue和OpenLayer在地圖上面添加風(fēng)場(chǎng)效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-04-04
  • vue 表單之通過v-model綁定單選按鈕radio

    vue 表單之通過v-model綁定單選按鈕radio

    這篇文章主要介紹了vue 表單之v-model綁定單選按鈕radio的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • Nuxt.js實(shí)戰(zhàn)詳解

    Nuxt.js實(shí)戰(zhàn)詳解

    這篇文章主要介紹了Nuxt.js實(shí)戰(zhàn)詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • VUE + OPENLAYERS實(shí)現(xiàn)實(shí)時(shí)定位功能

    VUE + OPENLAYERS實(shí)現(xiàn)實(shí)時(shí)定位功能

    本系列文章介紹一個(gè)簡單的實(shí)時(shí)定位示例,基于VUE + OPENLAYERS實(shí)現(xiàn)實(shí)時(shí)定位功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-09-09
  • Vue.js?element-plus使用圖標(biāo)不顯示問題的解決方式

    Vue.js?element-plus使用圖標(biāo)不顯示問題的解決方式

    近期在學(xué)習(xí)Vue時(shí)用elementUI時(shí)發(fā)現(xiàn)圖標(biāo)在頁面上顯示不出來,所以這篇文章主要給大家介紹了關(guān)于Vue.js?element-plus使用圖標(biāo)不顯示問題的解決方式,需要的朋友可以參考下
    2022-09-09
  • Vue 多選框所選數(shù)量動(dòng)態(tài)變換Box的高度

    Vue 多選框所選數(shù)量動(dòng)態(tài)變換Box的高度

    在Web開發(fā)中,使用Vue.js框架可以通過ref屬性、v-model指令和計(jì)算屬性等特性實(shí)現(xiàn)元素高度的動(dòng)態(tài)調(diào)整,文章詳細(xì)介紹了如何利用Vue的功能根據(jù)多選框的選擇數(shù)量動(dòng)態(tài)改變?cè)氐母叨?并通過多個(gè)示例展示其應(yīng)用
    2024-09-09
  • vue 解決遍歷對(duì)象顯示的順序不對(duì)問題

    vue 解決遍歷對(duì)象顯示的順序不對(duì)問題

    今天小編就為大家分享一篇vue 解決遍歷對(duì)象顯示的順序不對(duì)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue3中動(dòng)態(tài)修改樣式與級(jí)聯(lián)樣式優(yōu)先順序圖文詳解

    Vue3中動(dòng)態(tài)修改樣式與級(jí)聯(lián)樣式優(yōu)先順序圖文詳解

    在項(xiàng)目中,我們時(shí)常會(huì)遇到動(dòng)態(tài)的去綁定操作切換不同的CSS樣式,下面這篇文章主要給大家介紹了關(guān)于Vue3中動(dòng)態(tài)修改樣式與級(jí)聯(lián)樣式優(yōu)先順序的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • vue使用keep-alive如何實(shí)現(xiàn)多頁簽并支持強(qiáng)制刷新

    vue使用keep-alive如何實(shí)現(xiàn)多頁簽并支持強(qiáng)制刷新

    這篇文章主要介紹了vue使用keep-alive如何實(shí)現(xiàn)多頁簽并支持強(qiáng)制刷新,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 深入理解基于vue-cli的vuex配置

    深入理解基于vue-cli的vuex配置

    本篇文章主要介紹了基于vue-cli的vuex配置,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07

最新評(píng)論