vue混入mixin的使用,保证你看的明明白白!

简介: vue混入mixin的使用,保证你看的明明白白!

场景描述


有些时候,我们发现有些组件部分功能代码是几乎是一样的。


这个时候,我们就可以将相同的逻辑代码抽离出来


此时我们的主角混入mixin就登场了


下面我们有a-test和b-test两个组件,点击按钮发生的逻辑是一样的。


这个时候我们就可以使用混入mixin


a-test代码如下


<template>
    <div>
        <el-button  @click="openHander">点我呀</el-button>
        <h2 >我是a-test组件</h2>
        <h2>学校: {{ name}}</h2>
        <h2> 地址: {{ sex}}</h2>
        ============================
    </div>
</template>
<script>
import { mixinmethods} from "../mixin.js"
export default {
    data(){
        return {
            name:'xxx科技大学',
            sex:'四川'
        }
    },
    // methods:{
    //     openHander(){
    //         // 做了一些事情,因为跟b-test组件的功能相同,所以我们使用混入来解决
    //     }
    // }
    // mixins是固定的,里面传入一个数组
    mixins:[mixinmethods]
}
</script>


b-test组件代码如下


<template>
    <div>
        <el-button  @click="openHander">点我呀</el-button>
        <h2>我是b-test组件</h2>
        <h2> 学生姓名: {{ name}}</h2>
        <h2> 学生性别: {{ sex}}</h2>
    </div>
</template>
<script>
import { mixinmethods} from "../mixin.js"
    export default {
        data(){
            return {
                name:'李四',
                sex:'男'
            }
        },
        // methods:{
        //     openHander(){
        //         // 做了一些事情,因为跟a-test组件的功能相同,所以我们使用混入来解决
        //     }
        // }
        // mixins是固定的,里面传入一个数组
        mixins:[mixinmethods]
    }
</script>


mixin.js代码


export const mixinmethods = {
    // mixinmethods这个值随便你取
    methods:{
        openHander(){
            // mixin其实就是想将相同的模块抽离出去
            alert('混合')
            // 可分别拿到组件中的数据
            console.log(this.name);
        }
    }
}


1425695-20211028213127009-1078882426.png


在mixin中写声明周期


export const mixinmethods = {
    // mixinmethods这个值随便你取
    methods:{
        openHander(){
            // mixin其实就是想将相同的模块抽离出去
            alert('混合')
            // 可分别拿到组件中的数据
            console.log(this.name);
        }
    },
    // 因为这个混合在两个组件中使用,那么该声明周期就会被执行两次
    mounted() {
        console.log("我是混合中的生命周期")
    }
}


如果混合中的数据与组件中data的数据重复,会保留data中的数据


如果组件中data数据与混合中的数据重复了,


使用data中的数据。


组件中是可以直接使用混合中的数据的。


需要注意的是:声明周期不会以谁的为主


如果你在混合总共使用了生命周期,声明周期可能是都会执行。不会以谁的为主


export const mixinmethods = {
    data() {
        return {
            name:'lh',
            sex: '男',
            age:24
        }
    },
    // mixinmethods这个值随便你取
    methods:{
        openHander(){
            // mixin其实就是想将相同的模块抽离出去
            alert('混合')
            // 可分别拿到组件中的数据
            console.log(this.name);
        }
    },
    // 因为这个混合在两个组件中使用,那么该声明周期就会被执行两次
    mounted() {
        console.log("我是混合中的生命周期")
    }
}


<template>
    <div>
        <el-button @click="openHander">点我呀</el-button>
        <h2 >我是a-test组件</h2>
        <h2 >学校: {{ name}}</h2>
        <h2> 地址: {{ sex}}</h2>
        <h2> 年龄是混合中的数据 {{ age}}</h2>
        ============================
    </div>
</template>
<script>
import { mixinmethods} from "../mixin.js"
export default {
    data(){
        return {
            name:'xxx科技大学',
            sex:'四川'
        }
    },
    // mixins是固定的,里面传入一个数组
    mixins:[mixinmethods]
}
</script>


1425695-20211029194732626-949549033.png


全局混合


在main.js中全局引入,


这样vc,vm都可以得到[这样虽然是全局使用,但是会造成性能浪费]


import {yourkey1,yourkey2}  from "./mixn"


Vue.mixin(yourkey1)


Vue.mixin(yourkey2)


这样你就可以不需要在组件中引入了。直接在组件中使用混合就行


组件中使用 mixins:[yourkey1]

相关文章
|
6天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
21 0
|
6天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
1天前
|
JavaScript Java 关系型数据库
基于SprinBoot+vue的租房管理系统2
基于SprinBoot+vue的租房管理系统2
9 0
|
2天前
|
自然语言处理 JavaScript 数据可视化
5个值得推荐的Vue后台管理框架
几个优秀好看的 Vue 后台管理框架,每个框架都有自己的特点和优势,开发者可以根据项目需求选择适合的框架。
14 0
|
6天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
13 1
|
6天前
|
JavaScript 前端开发 定位技术
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
|
6天前
|
JavaScript
Vue中避免滥用this去读取data中数据
Vue中避免滥用this去读取data中数据
|
7天前
|
JavaScript
vue中使用pinia及持久化
vue中使用pinia及持久化
12 0
|
7天前
|
JavaScript 前端开发 UED
Vue class和style绑定:动态美化你的组件
Vue class和style绑定:动态美化你的组件
|
7天前
|
JavaScript 前端开发 API
Vue 监听器:让你的应用实时响应变化
Vue 监听器:让你的应用实时响应变化