美文网首页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的使用

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

  • vue的extend extends mixins

    一. 描述 extend 组件构造器,便于复用extends 实现继承组件mixins 对组件的扩充,可多个 1....

  • vue mixins和extends的通俗解说

    混合mixins和继承extends 看看官方文档怎么写的,其实两个都可以理解为继承,mixins接收对象数组(可...

  • extends和Vue.extend,Vue.component

    1.extends 看看官方文档怎么写的,其实mixins和extends都可以理解为继承,mixins接收对象数...

  • vue-api-组合

    extends 扩展 mixins 混入

  • 混合mixins和extends

    mixins(混入)用途: 减少源代码的污染:已经写好构造器后,需要增加方法或者临时使用的方法 减少代码量,实现代...

  • Vue 混入(mixins和Vue.mixin)

    1.mixins和Vue.mixin mixins 混入 (mixins) 是一种分发 Vue 组件中可复用功能的...

  • vue mixins的使用

    mixins是一种将组件功能复用的方式,简单来说就是讲组件的数据、钩子、方法、等封装在一个对象里面,然后在组建中m...

  • vue2中的mixins

    mixins: 混合对象, 功能类似于Vue.extend(); 使用时,在组件的选项中添加mixins: [mi...

  • Vue 之 Mixins (混入)

    Mixins Mixins是一种分发Vue组件中可复用功能的非常灵活的一种方式。 什么时候使用Mixins 页面的...

网友评论

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

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