vue的mixins的使用

mixins就是混入,将 根实例或是组件中的配置项 抽离出来, 单独管理

一个混入对象可以包含任意组件选项。

同一个生命周期,混入对象会比组件的先执行。

A:局部混入

var mixin = {
	methods: {
		sum(){
			alert( 10*10 )
		}
	},
}
new Vue({
	el: '#app',
	data: {},
	watch: {},
	mixins: [mixin],
	computed: {}
})

注意:

即使分离出去, 我们的配置项中也可以继续写分离出去的配置
如果说分离出去中的内容有冲突, 以组件中的配置项为准

B: 全局混入
注意: 全局混入慎用(不建议你使用)
理由:全局混入会影响所有的组件(实例)

Vue.mixin({
	watch: {},
	methods: {}
})

例如

<div id="app">
   <button @click = "sum"> 点击 </button>
   <button @click = "redecer"> 点击 </button>
   <button @click = "changeName"> 点击 </button>
</div>

 Vue.mixin({
   methods: {
     changeName(){
       alert('zhangsan')
     }
   }
 })
 new Vue({
   	el: '#app',
   	data: {},
   	watch: {},
   	methods: {
   		redecer(){
   			alert( 100-10 )
   		},
   		sum(){
   			alert('张三')
   		}
   	},
   	computed: {}
 })
下面整理一个完整的例子

1.创建一个test.js,用export暴露出mixins对象

export const mixinsTest = {
    methods:{
        hello(){
            console.log("hello");
            
        }
    },
    created(){
        this.hello()
    }
}

2.在组件中引入这个mixins对象,通过mixins:[xxx],使用mixins对象

<template>
<div>
    home
</div>
</template>
<script>
import {mixinsTest} from '../util/test.js'
export default {
  name: "Home",
  data () {
    return {
    };
  },
  created(){
      console.log("home");
      
  },
  //mixins的created会先被调用,然后再执行组件的created
  mixins:[mixinsTest]
}
</script>

补充:

可以混入多个mixins对象

//暴露两个mixins对象
export const mixinsTest = {
    methods: {
        hello() {
            console.log("hello mixins");
        }
    },
    created() {
        this.hello();
    },
}


export const mixinsTest2 = {
    methods:{
        hello2(){
            console.log("hello2");
        }
    },
    created() {
        this.hello2();
    },
}

组件中引入两个mixins对象

<template>
<div>
    home
</div>
</template>
<script>
import {mixinsTest,mixinsTest2} from '../util/test.js'
export default {
  name: "Home",
  data () {
    return {
    };
  },
  created(){
      console.log("1212");
  },
  mixins:[mixinsTest2,mixinsTest] // 先调用那个mixins对象,就先执行哪个
 
}
</script>
<style lang="css" scoped>
</style>

打印的顺序是:

hello2
hello2 mixins
1212
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值