vue之mixin混入

vue之mixin混入

mixin是什么?

官方的解释:

混入 (mixin) 提供了一种非常灵活的方式,来分发 Vue 组件中的可复用功能。一个混入对象可以包含任意组件选项。当组件使用混入对象时,所有混入对象的选项将被"混合"进入该组件本身的选项。

感觉有点难以理解,其实简单来说:就是将组件的公共逻辑或者配置提取出来,哪个组件需要用到,直接将提取的这部分混入到组件内部即可,提取的是逻辑或配置,而不是HTML代码和CSS代码。

mixin的特点

mixin中的数据和方法都是独立的,组件之间使用后是互相不影响的。

使用

1.定义mixin.js文件

mixin是一个对象,但是本身也是有生命周期的,可以定义属性和方法等

javascript 复制代码
export const mixins = {
  data() {
    return {
      msg: "我是原本的结果",
    };
  },
  computed: {},
  created() {
    console.log("我是mixin中的created生命周期函数");
  },
  mounted() {
    console.log("我是mixin中的mounted生命周期函数");
  },
  methods: {
    clickMe() {
      console.log("我是mixin中的点击事件");
    },
  },
};

mixin.js中的msg,clickMe在混入其他组件后都可以直接使用。

2.局部混入

index.vue文件

javascript 复制代码
<template>
  <div id="app">
    <button @click="clickMe">点击我</button>
    <button @click="changeMsg">更改mixin数据</button>
	点击更换的数据:{{msg}}
    <demo></demo>
  </div>
</template>

<script>
import { mixins } from "@/mixin/index.js";
import demo from "./demo.vue";
export default {
  name: "App",
  mixins: [mixins],
  components: { demo },
  created() {
    console.log("组件调用minxi数据", this.msg);
  },
  mounted() {
    console.log("我是组件的mounted生命周期函数");
  },
  methods: {
    changeMsg() {
      this.msg = "我是点击后的结果";
      console.log("更改后的msg:", this.msg);
    },
  },
};
</script>

在混入mixin.js同时导入一个混入过的demo.vue组件,来验证一下同一个数据之间是否相互影响。
demo.vue

javascript 复制代码
<template>
  <div>mixin中的数据:{{ msg }}</div>
</template>
<script>
import { mixins } from "@/mixin/index.js";
export default {
  mixins: [mixins],
};
</script>

经过测试发现是不影响的。

3.生命周期的执行顺序:

这是没有带入demo组件时候,生命周期的执行顺序:

导入demo组件后的生命周期:

4.冲突

如果属性名或者方法名冲突的话如何执行呢?四个字总结就是就近原则,组件本身有会覆盖混入的。

5.全局混入

在main.js中导入注册即可

javascript 复制代码
import { mixins } from "@/mixin/index.js";
Vue.mixin(mixins);
相关推荐
小二·3 分钟前
Python Web 开发进阶实战:国际化(i18n)与多语言支持 —— Vue I18n + Flask-Babel 全栈解决方案
前端·vue.js·python
全栈前端老曹4 分钟前
【包管理】npm最常见的10大问题故障和解决方案
前端·javascript·rust·npm·node.js·json·最佳实践
摘星编程5 分钟前
React Native for OpenHarmony 实战:Easing 动画缓动函数详解
javascript·react native·react.js
weixin_427771619 分钟前
pnpm 改造
前端
岁岁种桃花儿9 分钟前
Spring Boot Maven插件核心配置详解:从打包到部署全流程
前端·firefox·springboot
小二·10 分钟前
Python Web 开发进阶实战:API 安全与 JWT 认证 —— 构建企业级 RESTful 接口
前端·python·安全
摸鱼的春哥10 分钟前
继续AI编排实战:带截图的连麦切片文章生成
前端·javascript·后端
前端切图仔00111 分钟前
Chrome 扩展程序上架指南
android·java·javascript·google
出了名的洗发水13 分钟前
科技感404页面
前端·科技·html
2501_9481226314 分钟前
React Native for OpenHarmony 实战:Steam 资讯 App 浏览历史页面
javascript·react native·react.js·游戏·ecmascript·harmonyos