偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Vue3 學(xué)習(xí)筆記 —mixin 混入

開(kāi)發(fā) 前端
mixin 混入,提供了一種非常靈活的方式,來(lái)分發(fā) vue 組件中的可復(fù)用功能,一個(gè)mixin 對(duì)象可以包含任意組件選項(xiàng),當(dāng)組件使用 mixin 對(duì)象時(shí),所有的 mixin 對(duì)象的選項(xiàng)將被混入組件本身的選項(xiàng)。

[[435190]]

vue 2 中采用選項(xiàng)式API。如:data、methods、watch、computed以及生命周期鉤子函數(shù)等等。

mixin 混入,提供了一種非常靈活的方式,來(lái)分發(fā) vue 組件中的可復(fù)用功能,一個(gè)mixin 對(duì)象可以包含任意組件選項(xiàng),當(dāng)組件使用 mixin 對(duì)象時(shí),所有的 mixin 對(duì)象的選項(xiàng)將被混入組件本身的選項(xiàng)。

一、mixin 如何使用 ?

通俗地講,mixin 對(duì)象把一些組件公用的選項(xiàng),如data內(nèi)數(shù)據(jù),方法、計(jì)算屬性、生命周期鉤子函數(shù),單獨(dú)提取出來(lái),然后在組件內(nèi)引入,就可以與組件本身的選項(xiàng)進(jìn)行合并。

示例1:

  1. <script> 
  2. const myMixin = { 
  3.  data(){ 
  4.   return { 
  5.    num:520 
  6.   } 
  7.  }, 
  8.  mounted(){ 
  9.   console.log('mixin mounted'); 
  10.  } 
  11. export default { 
  12.   mixins:[myMixin], 
  13. </script> 

就相當(dāng)于:

  1. <script> 
  2. export default { 
  3.  data(){ 
  4.   return { 
  5.    num:520 
  6.   } 
  7.  }, 
  8.  mounted(){ 
  9.   console.log('mixin mounted'); 
  10.  } 
  11. </script> 

這樣做的好處就是可以把多個(gè)組件公共選項(xiàng)抽取到一個(gè) mixin 對(duì)象內(nèi),需要的時(shí)候直接引入就可以了。

二、mixin 使用時(shí)注意點(diǎn)

mixin 包含的選項(xiàng),同時(shí)組件內(nèi)也可以包含這些選項(xiàng),如果 mixin 中包含的選項(xiàng)中,有部分屬性相同怎么辦?如 mixin 和組件內(nèi)都存在一個(gè)同名方法時(shí),如何處理?或者都包含生命周期鉤子函數(shù)時(shí),它們的執(zhí)行順序誰(shuí)前誰(shuí)后呢?接下來(lái)我們就看看,使用 mixin 時(shí)應(yīng)該注意的點(diǎn)。

2.1、使用 mixin 對(duì)象時(shí),組件內(nèi)部和 mixin 包含相同選項(xiàng),如何處理呢?

示例2:mixin 對(duì)象和實(shí)例都包含data選項(xiàng),內(nèi)部有兩個(gè)不同的變量

  1. <template> 
  2.  <div> 
  3.   {{qdr}}  -   {{name}}  
  4.  </div> 
  5. </template> 
  6. <script> 
  7. const myMixin = { 
  8.  data(){ 
  9.   return { 
  10.    name:'熱愛(ài)前端的小姐姐' 
  11.   } 
  12.  } 
  13. export default { 
  14.  mixins:[myMixin], 
  15.  data(){ 
  16.   return { 
  17.    qdr:"前端人" 
  18.   } 
  19.  } 
  20. </script> 

運(yùn)行后,我們發(fā)現(xiàn)兩個(gè)變量都能使用,mixin 對(duì)象中的 data 與實(shí)例中的 data 選項(xiàng)進(jìn)行合并了。對(duì)于 methods 、computed 也是一樣的。

如果我們把上個(gè)實(shí)例中的兩個(gè)變量,修改成同名時(shí),會(huì)怎樣呢?

2.2、使用的 mixin 對(duì)象選項(xiàng) 和實(shí)例中的選項(xiàng)擁有相同的屬性該如何處理?

示例3:data 內(nèi)擁有相同的變量名 name

  1. <template> 
  2.  <div> 
  3.   {{name}}  
  4.  </div> 
  5. </template> 
  6. <script> 
  7. const myMixin = { 
  8.  data(){ 
  9.   return { 
  10.    name:'熱愛(ài)前端的小姐姐' 
  11.   } 
  12.  } 
  13. export default { 
  14.  mixins:[myMixin], 
  15.  data(){ 
  16.   return { 
  17.    name:"前端人" 
  18.   } 
  19.  } 
  20. </script> 

運(yùn)行結(jié)果,name 值為 “前端人”。

屬性值相同時(shí),會(huì)選擇就近原則,優(yōu)先繼承實(shí)例內(nèi)的值,所以 mixin 對(duì)象的屬性會(huì)被實(shí)例中的屬性給覆蓋掉。

2.3、mixin 對(duì)象也可以添加生命周期鉤子函數(shù),mixin 和 實(shí)例中 的那個(gè)優(yōu)先執(zhí)行呢?

示例4:mixin 加入生命周期鉤子函數(shù),以 mounted 為例

  1. const myMixin = { 
  2.  mounted(){ 
  3.   console.log('mixin mounted'); 
  4.  } 
  5. export default { 
  6.  mixins:[myMixin], 
  7.  mounted(){ 
  8.   console.log('mounted'); 
  9.  } 

 運(yùn)行結(jié)果:

vue3 學(xué)習(xí)筆記 (一)——mixin 混入

我們發(fā)現(xiàn)生命周期函數(shù)會(huì)合并執(zhí)行,優(yōu)先執(zhí)行 mixin 中的, 然后再執(zhí)行實(shí)例中的。

三、mixin 自定義屬性

$options 用于當(dāng)前組件實(shí)例 的初始化選項(xiàng),需要在選項(xiàng)中包含自定義 property 時(shí)會(huì)有用處。

簡(jiǎn)單講,$options 用于在實(shí)例中調(diào)用 mixin 自定義屬性。

示例5:添加自定義屬性

  1. const myMixin = { 
  2.   custom:'自定義屬性' 
  3.  } 

 在實(shí)例中使用:

  1. mounted(){ 
  2.  console.log(this.$options.custom); 

 如果在實(shí)例中也包含一個(gè)同名自定義屬性時(shí),優(yōu)先級(jí)會(huì)作何處理呢?如果我們想控制優(yōu)先級(jí)又該如何處理呢?

四、合并策略

optionMergeStrategies 選項(xiàng)合并策略,使用 mixin 自定義屬性和實(shí)例中的屬性沖突時(shí),使用optionMergeStrategies 定義合并規(guī)則的,也就是優(yōu)先使用誰(shuí)的問(wèn)題。

使用規(guī)則:

  1. app.config.optionMergeStrategies.propertyName=(mixinVal,appVal)=>{ 
  2.   return appVal || mixinVal  // 確定優(yōu)先返回哪個(gè)屬性值 

 根據(jù)上述示例5,給實(shí)例中加 custom 屬性,運(yùn)行查看結(jié)果。

示例6:驗(yàn)證 mixin 和 實(shí)例 屬性優(yōu)先級(jí)

  1. <script> 
  2. const myMixin = { 
  3.   custom:'mixin custom'
  4. export default { 
  5.   custom:'app custom'
  6.   mixins:[myMixin], 
  7.   mounted(){ 
  8.     console.log(this.$options.custom); // 打印結(jié)果:app custom 
  9.   } 
  10. </script> 

發(fā)現(xiàn),mixin 對(duì)象中的屬性值被實(shí)例中屬性值覆蓋掉了。我們可以借用上述的 optionMergeStrategies 屬性,修改 custom 的合并規(guī)則。

在 main.js 文件內(nèi)引入:

  1. app.config.optionMergeStrategies.custom=(mixinVal,appVal)=>{ 
  2.  return mixinVal ||  appVal 

 再次運(yùn)行之后,我們發(fā)現(xiàn)打印結(jié)果變成 mixin 中的屬性值了:

console.log(this.$options.custom); // 打印結(jié)果:mixin custom

五、全局配置 mixin

如果項(xiàng)目中有多個(gè)組件復(fù)用某些選項(xiàng)時(shí),我們可以通過(guò)全局使用 mixin 對(duì)象。一個(gè)實(shí)例也可以引入多個(gè) mixin 對(duì)象。語(yǔ)法如下:

  1. app.mixin([ {}, {}, {} ]) 

 

責(zé)任編輯:姜華 來(lái)源: 今日頭條
相關(guān)推薦

2021-12-01 08:11:44

Vue3 插件Vue應(yīng)用

2021-11-30 08:19:43

Vue3 插件Vue應(yīng)用

2023-11-28 09:03:59

Vue.jsJavaScript

2021-12-29 07:51:21

Vue3 插件Vue應(yīng)用

2021-12-02 05:50:35

Vue3 插件Vue應(yīng)用

2021-12-08 09:09:33

Vue 3 Computed Vue2

2023-12-11 07:34:37

Computed計(jì)算屬性Vue3

2021-11-17 08:24:47

Vue3 插件Vue應(yīng)用

2023-12-14 08:25:14

WatchVue.js監(jiān)聽(tīng)數(shù)據(jù)

2023-11-29 08:49:31

Vue.jsData 函數(shù)

2021-11-26 05:59:31

Vue3 插件Vue應(yīng)用

2023-12-06 07:43:56

Vue如何定義事件

2020-09-19 21:15:26

Composition

2021-12-15 08:23:42

Vue3 插件Vue應(yīng)用

2025-10-17 07:10:00

前端開(kāi)發(fā)Vue

2021-12-07 05:44:45

Vue 3 Watch WatchEffect

2021-05-26 10:40:28

Vue3TypeScript前端

2022-03-10 11:04:04

Vue3Canvas前端

2022-06-21 12:09:18

Vue差異

2024-11-06 10:16:22

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)