Vue组件公用方法提取mixin实现

作者:什么都干的派森 时间:2024-06-07 16:02:47 

一.应用场景

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

二.实现方法

1.提取js共用方法文件

Vue组件公用方法提取mixin实现

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中&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 => h(App),
}).$mount('#app')

来源:https://blog.csdn.net/weixin_43721000/article/details/123603990

标签:Vue,组件,提取,mixin
0
投稿

猜你喜欢

  • 深入Golang的接口interface

    2024-02-20 14:12:00
  • Python字符串格式化输出方法分析

    2022-03-24 22:18:45
  • 详解MindSpore自定义模型损失函数

    2022-07-24 09:41:34
  • python中pandas.DataFrame的简单操作方法(创建、索引、增添与删除)

    2021-05-15 16:25:58
  • 利用Django模版生成树状结构实例代码

    2023-11-10 16:41:11
  • MySQL 修改密码实例详解

    2024-01-27 05:36:28
  • Python基于list的append和pop方法实现堆栈与队列功能示例

    2022-10-20 02:26:26
  • PIL.Image.open和cv2.imread的比较与相互转换的方法

    2021-05-06 22:09:38
  • mysql登录遇到ERROR 1045问题解决方法

    2024-01-22 15:09:57
  • python 实现简单的FTP程序

    2021-03-29 10:33:00
  • Flask 使用工厂模式

    2021-10-01 01:52:58
  • django model object序列化实例

    2022-07-03 14:55:24
  • Win10下为VSCode配置LaTex编辑器的方法

    2023-08-27 17:20:07
  • Django外键(ForeignKey)操作以及related_name的作用详解

    2023-03-15 22:48:09
  • Django CSRF跨站请求伪造防护过程解析

    2021-04-15 03:00:50
  • 详解vue-cli 脚手架 安装

    2024-05-09 10:40:06
  • 语义化的label?

    2009-02-11 12:44:00
  • IE下文本被折行的解决方案

    2009-06-28 16:13:00
  • JAVA正则表达式校验qq号码的方法

    2023-08-09 02:54:25
  • 聊聊golang中多个defer的执行顺序

    2023-09-03 09:23:22
  • asp之家 网络编程 m.aspxhome.com