mixins就是混入。
一个混入对象可以包含任意组件选项。
同一个生命周期,混入对象会比组件的先执行。
export const mixinsTest = { methods:{ hello(){ console.log("hello"); } }, created(){ this.hello() } }
<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>
打印:hello
补充:
vue的extends和mixins类似,通过暴露一个extends对象到组件中使用。
extends会比mixins先执行。执行顺序:extends > mixins > 组件
extends只能暴露一个extends对象,暴露多个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(); }, }
<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>
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!