成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Vue3 學習筆記 —mixin 混入

開發 前端
mixin 混入,提供了一種非常靈活的方式,來分發 vue 組件中的可復用功能,一個mixin 對象可以包含任意組件選項,當組件使用 mixin 對象時,所有的 mixin 對象的選項將被混入組件本身的選項。

[[435190]]

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

mixin 混入,提供了一種非常靈活的方式,來分發 vue 組件中的可復用功能,一個mixin 對象可以包含任意組件選項,當組件使用 mixin 對象時,所有的 mixin 對象的選項將被混入組件本身的選項。

一、mixin 如何使用 ?

通俗地講,mixin 對象把一些組件公用的選項,如data內數據,方法、計算屬性、生命周期鉤子函數,單獨提取出來,然后在組件內引入,就可以與組件本身的選項進行合并。

示例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> 

就相當于:

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

這樣做的好處就是可以把多個組件公共選項抽取到一個 mixin 對象內,需要的時候直接引入就可以了。

二、mixin 使用時注意點

mixin 包含的選項,同時組件內也可以包含這些選項,如果 mixin 中包含的選項中,有部分屬性相同怎么辦?如 mixin 和組件內都存在一個同名方法時,如何處理?或者都包含生命周期鉤子函數時,它們的執行順序誰前誰后呢?接下來我們就看看,使用 mixin 時應該注意的點。

2.1、使用 mixin 對象時,組件內部和 mixin 包含相同選項,如何處理呢?

示例2:mixin 對象和實例都包含data選項,內部有兩個不同的變量

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

運行后,我們發現兩個變量都能使用,mixin 對象中的 data 與實例中的 data 選項進行合并了。對于 methods 、computed 也是一樣的。

如果我們把上個實例中的兩個變量,修改成同名時,會怎樣呢?

2.2、使用的 mixin 對象選項 和實例中的選項擁有相同的屬性該如何處理?

示例3:data 內擁有相同的變量名 name

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

運行結果,name 值為 “前端人”。

屬性值相同時,會選擇就近原則,優先繼承實例內的值,所以 mixin 對象的屬性會被實例中的屬性給覆蓋掉。

2.3、mixin 對象也可以添加生命周期鉤子函數,mixin 和 實例中 的那個優先執行呢?

示例4:mixin 加入生命周期鉤子函數,以 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.  } 

 運行結果:

vue3 學習筆記 (一)——mixin 混入

我們發現生命周期函數會合并執行,優先執行 mixin 中的, 然后再執行實例中的。

三、mixin 自定義屬性

$options 用于當前組件實例 的初始化選項,需要在選項中包含自定義 property 時會有用處。

簡單講,$options 用于在實例中調用 mixin 自定義屬性。

示例5:添加自定義屬性

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

 在實例中使用:

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

 如果在實例中也包含一個同名自定義屬性時,優先級會作何處理呢?如果我們想控制優先級又該如何處理呢?

四、合并策略

optionMergeStrategies 選項合并策略,使用 mixin 自定義屬性和實例中的屬性沖突時,使用optionMergeStrategies 定義合并規則的,也就是優先使用誰的問題。

使用規則:

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

 根據上述示例5,給實例中加 custom 屬性,運行查看結果。

示例6:驗證 mixin 和 實例 屬性優先級

  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); // 打印結果:app custom 
  9.   } 
  10. </script> 

發現,mixin 對象中的屬性值被實例中屬性值覆蓋掉了。我們可以借用上述的 optionMergeStrategies 屬性,修改 custom 的合并規則。

在 main.js 文件內引入:

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

 再次運行之后,我們發現打印結果變成 mixin 中的屬性值了:

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

五、全局配置 mixin

如果項目中有多個組件復用某些選項時,我們可以通過全局使用 mixin 對象。一個實例也可以引入多個 mixin 對象。語法如下:

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

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-12-01 08:11:44

Vue3 插件Vue應用

2021-11-30 08:19:43

Vue3 插件Vue應用

2023-11-28 09:03:59

Vue.jsJavaScript

2021-12-29 07:51:21

Vue3 插件Vue應用

2021-12-02 05:50:35

Vue3 插件Vue應用

2021-12-08 09:09:33

Vue 3 Computed Vue2

2023-12-11 07:34:37

Computed計算屬性Vue3

2021-11-17 08:24:47

Vue3 插件Vue應用

2023-12-14 08:25:14

WatchVue.js監聽數據

2023-11-29 08:49:31

Vue.jsData 函數

2021-11-26 05:59:31

Vue3 插件Vue應用

2023-12-06 07:43:56

Vue如何定義事件

2020-09-19 21:15:26

Composition

2021-12-15 08:23:42

Vue3 插件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前端

2024-11-06 10:16:22

2022-06-21 12:09:18

Vue差異

2017-07-14 10:10:08

Vue.jsMixin
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线免费观看日本 | 国产精品成人一区 | 99久久精品国产毛片 | 视频第一区 | 日韩精品在线视频 | 欧美一区在线视频 | 国产专区视频 | av第一页| 精品中文字幕一区二区三区 | 成人在线视频网 | 国产一区二区高清在线 | 久久久国产一区 | 国产精品毛片无码 | 黄频免费| 在线观看中文字幕视频 | 激情欧美一区二区三区中文字幕 | 国产精品久久久久久福利一牛影视 | 91亚洲精 | 精品av| 天天插天天搞 | 国产一级在线观看 | 国产女人第一次做爰毛片 | 久久久久久久久久久91 | 精品国产欧美一区二区三区不卡 | 精品免费视频一区二区 | 人人做人人澡人人爽欧美 | 久久人人爽人人爽 | 成人国内精品久久久久一区 | 99久久99久久精品国产片果冰 | 鲁一鲁资源影视 | 日韩av成人| www亚洲精品 | 亚洲欧洲精品在线 | 99re在线视频| 黄色片av | 91黄在线观看 | 在线播放一区二区三区 | 成人免费一区二区三区视频网站 | 国产精品久久久久久久久久免费看 | 成人小视频在线观看 | 欧美一级在线免费 |