mixins就是混入。
一个混入对象可以包含任意组件选项。
同一个生命周期,混入对象会比组件的先执行。
- 创建一个test.js,用export暴露出mixins对象
export const mixinsTest = {
methods:{
hello(){
console.log("hello");
}
},
created(){
this.hello()
}
}
- 在组件中引入这个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>
打印:
补充:
vue的extends和mixins类似,通过暴露一个extends对象到组件中使用。
extends会比mixins先执行。执行顺序:extends > mixins > 组件
extends只能暴露一个extends对象,暴露多个extends不会执行。
- 创建一个test.js,用export暴露出多个 mixins/extends 对象
export const mixinsTest = {
methods: {
hello() {
console.log("hello_mixins");
}
},
beforeCreate(){
console.log("混入的beforeCreated");
},
created() {
this.hello();
},
}
export const mixinsTest2 = {
methods:{
hello2(){
console.log("hello_mixins2");
}
},
created() {
this.hello2();
},
}
//只能使用一个extends对象,多个无效,extends会先于mixins执行
export const extendsTest = {
methods: {
hello3() {
console.log("hello_extends");
}
},
beforeCreate(){
console.log("extends的beforeCreated");
},
created() {
this.hello3();
},
}
- vue组件
<template>
<div>
home
</div>
</template>
<script>
import {mixinsTest,mixinsTest2,extendsTest} from '../util/test.js'
export default {
name: "Home",
data () {
return {
};
},
beforeCreate(){
console.log("组件的beforeCreated");
},
created(){
console.log("1212");
},
mixins:[mixinsTest2,mixinsTest], // 先调用那个mixins对象,就先执行哪个
extends:extendsTest // 使用extends
}
</script>
<style lang="css" scoped>
</style>
网友评论