美文网首页vue
vue的extends和mixins的使用

vue的extends和mixins的使用

作者: 刘其瑞 | 来源:发表于2019-12-25 20:34 被阅读0次

    mixins就是混入。
    一个混入对象可以包含任意组件选项。
    同一个生命周期,混入对象会比组件的先执行。

    1. 创建一个test.js,用export暴露出mixins对象
    export const mixinsTest = {
        methods:{
            hello(){
                console.log("hello");
                
            }
        },
        created(){
            this.hello()
        }
    }
    
    1. 在组件中引入这个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不会执行。


    1. 创建一个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();
        },
    }
    
    1. 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>
    

    相关文章

      网友评论

        本文标题:vue的extends和mixins的使用

        本文链接:https://www.haomeiwen.com/subject/pxkhoctx.html