我是靠谱客的博主 无奈小天鹅,最近开发中收集的这篇文章主要介绍Vue组件公用方法如何提取mixin,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

这篇文章主要介绍了Vue组件公用方法提取mixin实现,多个组件共用一个方法时可以用 mixin 抽取到一个js文件中,作为共用方法,下面一起进入文章了解更多详细内容吧

一.应用场景

多个组件共用一个方法时可以用 mixin 抽取到一个js文件中,作为共用方法

二.实现方法

1.提取js共用方法文件

export const common = {
     
    // 组件共用属性 ----------------------------------
    data() {
        return {
            age: 18                    // 设置一个共用属性
        }
    },
    // ---------------------------------------------
     
    // 组件共用方法 ---------------------------------------------
    methods: {
        showName() {
            alert(this.name)          // 弹出组件中name属性的共用方法
        }
    },
    // --------------------------------------------------------
     
    // 组件挂载时的共用方法 ----------------------
    mounted() {
        console.log('初始化方法')    // 挂载时调用
    },
    // ----------------------------------------
     
}

2.引入

< template>
    < div>
        < div>组件< /div>
        < button @click="showName">弹出姓名< /button>
    < /div>
< /template>
 
< script>
 
    // 引入js文件中的方法对象 --------------------
    import {common, } from '../pub_js/common.js'
    // ----------------------------------------
     
    export default {
        name: 'Student',
        data() {
            return {
                name: '张三'
            }
        },
         
        // 调用 mixin 将组件js与共用js合并 ---
        mixins: [common, ],
        // --------------------------------
         
    }
< /script>

三.注意事项

1.data中的属性合并后,如果有命名冲突的情况,以组件中的属性为主,【组件属性覆盖共用js中的属性】

2.methods中的方法合并后,如果有命名冲突的情况,以组件中的方法为主,【组件方法覆盖共用js中的方法】

3.mounted等生命周期方法合并后,会先调用共用js中的的生命周期函数,再调用组件中的生命周期函数,【不会进行覆盖】

4.如果是全局共用的方法,可以直挂载到main.js中↓

import Vue from 'vue'
import App from './App.vue'
 
Vue.config.productionTip = false
 
// 挂载全局共用方法 -----------------------
import {common, } from 'pub_js/common.js'
Vue.mixin(common)
// --------------------------------------
 
new Vue({
  render: h => h(App),
}).$mount('#app')

 

最后

以上就是无奈小天鹅为你收集整理的Vue组件公用方法如何提取mixin的全部内容,希望文章能够帮你解决Vue组件公用方法如何提取mixin所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(59)

评论列表共有 0 条评论

立即
投稿
返回
顶部