vue的mixins的使用
mixins就是混入。
一个混入对象可以包含任意组件选项。
同一个生命周期,混入对象会比组件的先执行。
1.创建一个test.js,用export暴露出mixins对象

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

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>

打印的顺序是:
test1
home

补充:
可以混入多个mixins对象

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

组件中引入两个mixins对象:

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

打印的顺序是:
test1
test2
home

Logo

前往低代码交流专区

更多推荐