vue的extends和mixins類似,通過暴露一個extends對象到組件中使用。
extends會比mixins先執行。執行順序:extends > mixins > 組件
extends只能暴露一個extends對象,暴露多個extends不會執行
test.js
//暴露兩個mixins對象 export const mixinsTest = { methods: { hello() { console.log("hello mixins"); } }, beforeCreate(){ console.log("混入的beforeCreated"); }, created() { this.hello(); }, } export const mixinsTest2 = { methods:{ hello2(){ console.log("hello2"); } }, 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>