好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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.引入lt;templategt;?? ?lt;divgt;?? ??? ?lt;divgt;组件lt;/divgt;?? ??? ?lt;button @click="showName"gt;弹出姓名lt;/buttongt;?? ?lt;/divgt;lt;/templategt;lt;scriptgt;?? ?// 引入js文件中的方法对象 --------------------?? ?import {common, } from 'pub_js/common.js'?? ?// ----------------------------------------?? ??? ?export default {?? ??? ?name: 'Student',?? ??? ?data() {?? ??? ??? ?return {?? ??? ??? ??? ?name: '张三'?? ??? ??? ?}?? ??? ?},?? ??? ??? ??? ?// 调用 mixin 将组件js与共用js合并 ---?? ??? ?mixins: [common, ],?? ??? ?// --------------------------------?? ??? ??? ?}lt;/scriptgt;

三.注意事项1.data中的属性合并后,如果有命名冲突的情况,以组件中的属性为主,【组件属性覆盖共用js中的属性】2.methods中的方法合并后,如果有命名冲突的情况,以组件中的方法为主,【组件方法覆盖共用js中的方法】3.mounted等生命周期方法合并后,会先调用共用js中的的生命周期函数,再调用组件中的生命周期函数,【不会进行覆盖】4.如果是全局共用的方法,可以直挂载到main.js中darr;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 =gt; h(App),}).$mount('#app')

这就是这篇关于Vue组件公共方法提取mixin实现的文章。更多相关Vue组件提取内容,请搜索源搜网之前的文章或者继续浏览下面的相关文章。希望大家以后能多支持源搜网!

查看更多关于Vue组件公共方法提取mixin实现的详细内容...

  阅读:29次