关于Vue.mixin在vue官方文档中是这么解释的:

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

  我们的理解:Vue.mixin给我们提供了一种混入Vue实例的方法,创建了混入对象之后,我们自定义的方法或者变量可以很轻松的挂载在Vue实例上,给我们的偷懒带来方便;

  Vue.mixin为我们提供了两种混入方式:局部混入和全局混入;

  本文还是以demo形式来进行学习讲解,如果有条件最好还是跟着demo敲一遍,这样印象才会深刻;

  局部混入:

    顾名思义就是部分混入,也就是只有引入了mixin的混入对象才可以使用,并且只有在引入了mixin混入对象的组件中才生效;

      来,知道了概念,我们一起来看看代码:

    首先自己搭建Vue的开发环境,然后我们在src目录中新建两个vue文件,分别是page1.vue和page2.vue;

    page1.vue

  1. <template>
  2. <div>page1的值是:</div>
  3. </template>
  4.  
  5. <script>
  6. export default {
  7. data () {
  8. return {
  9.  
  10. }
  11. },
  12. }
  13. </script>
  14.  
  15. <style scoped>
  16.  
  17. </style>

    page2.vue

  1. <template>
  2. <div>page2的值是:</div>
  3. </template>
  4.  
  5. <script>
  6. export default {
  7. data () {
  8. return {
  9.  
  10. }
  11. }
  12. }
  13. </script>
  14.  
  15. <style scoped>
  16.  
  17. </style>

  然后我们修改App.vue

  1. <template>
  2. <div id="app">
  3. <button @click="method1">page1</button>
  4. <button @click="method2">page2</button>
  5.  
  6. <router-view></router-view>
  7. </div>
  8. </template>
  9.  
  10. <script>
  11. export default {
  12. name: 'App',
  13. methods:{
  14. method1(){
  15. this.$router.push('/page1');
  16. },
  17. method2(){
  18. this.$router.push('/page2');
  19. }
  20. }
  21. }
  22. </script>
  23.  
  24. <style>
  25. #app {
  26. font-family: 'Avenir', Helvetica, Arial, sans-serif;
  27. -webkit-font-smoothing: antialiased;
  28. -moz-osx-font-smoothing: grayscale;
  29. text-align: center;
  30. color: #2c3e50;
  31. margin-top: 60px;
  32. }
  33. </style>

  在src目录下创建router.js文件,配置路由实现跳转

  1. import Vue from "vue";
  2. import VueRouter from "vue-router";
  3. Vue.use(VueRouter);
  4.  
  5. import page1 from "./page1";
  6. import page2 from "./page2";
  7.  
  8. const routes=[
  9. {path:"/page1",component:page1},
  10. {path:"/page2",component:page2}
  11. ]
  12.  
  13. const router=new VueRouter({
  14. routes
  15. })
  16.  
  17. export default router

  最后将路由引入main.js中:

  1. // The Vue build version to load with the `import` command
  2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
  3. import Vue from 'vue'
  4. import App from './App'
  5. import router from './router.js'
  6.  
  7. Vue.config.productionTip = false
  8.  
  9. /* eslint-disable no-new */
  10. new Vue({
  11. el: '#app',
  12. router,
  13. components: { App },
  14. template: '<App/>'
  15. })

  完成上述准备工作之后,我们可以看到现在的页面效果如下:

  没有报错,我们开始正式进入学习Vue.mixin:

  首先我们在src目录下新建一个名为mixin的文件夹并在mixin文件中创建一个mixin.js文件:

  1. //抛出混入对象,方便外部访问
  2. export const mixin={
  3. data(){
  4. return {
  5. number:1
  6. }
  7. }
  8. }

  可以看到我们在混入对象中创建了一个变量,是的,混入对象跟Vue实例的格式是一样的;

  然后我们可以将mixin.js引入到我们的page1.vue和page2.vue中

  page1.vue

  1. <template>
  2. //这里读的值其实是mixin的值,因为这个时候mixin已经混入到vue实例中了
  3. <div>page1的值是:{{number}}</div>
  4. </template>
  5.  
  6. <script>
  7. //引入mixin.js
  8. import {mixin} from "./mixin/mixin"
  9. export default {
  10. //这里注意:属性名为mixins,值为数组类型
  11. mixins:[mixin],
  12. data () {
  13. return {
  14.  
  15. }
  16. },
  17. }
  18. </script>
  19.  
  20. <style scoped>
  21.  
  22. </style>

  page2.vue

  1. <template>
  2. <div>page2的值是:{{number}}</div>
  3. </template>
  4.  
  5. <script>
  6. import {mixin} from "./mixin/mixin"
  7. export default {
  8. mixins:[mixin],
  9. data () {
  10. return {
  11.  
  12. }
  13. }
  14. }
  15. </script>
  16.  
  17. <style scoped>
  18.  
  19. </style>

  这个时候我们的混入对象已经成功混入到Vue实例中,你们可以点击看看效果,是可以正常运行并且能读取到值的;

  现在我们来修改page1.vue的代码: 

  1. <template>
  2. <div>page2的值是:{{number}}</div>
  3. </template>
  4.  
  5. <script>
  6. import {mixin} from "./mixin/mixin"
  7. export default {
  8. mixins:[mixin],
  9. data () {
  10. return {
  11.  
  12. }
  13. }
  14. }
  15. </script>
  16.  
  17. <style scoped>
  18.  
  19. </style>

  page2不变,再运行可以发现,我们的page1.vue中的值是执行了mounted,所以产生了自增

  由此,我们可以知道mixin混入对象的变量是不会共享的;也就是你page1发生了变化,并不会通知mixin进行实时刷新数据,发生的变化只会在page1.vue中生效,不影响其他组件;

  现在我们修改mixin.js和page1.vue中的代码:

  mixin.js

  1. export const mixin={
  2. data(){
  3. return {
  4. number:1
  5. }
  6. },
  7. created(){
  8. console.log("mixin混入对象")
  9. }
  10. }

  page1.vue

  1. <template>
  2. <div>page1的值是:{{number}}</div>
  3. </template>
  4.  
  5. <script>
  6. import {mixin} from "./mixin/mixin"
  7. export default {
  8. mixins:[mixin],
  9. data () {
  10. return {
  11.  
  12. }
  13. },
  14. created(){
  15. console.log("这里是page1");
  16. }
  17. }
  18. </script>
  19.  
  20. <style scoped>
  21.  
  22. </style>

  这个时候我们再运行可以发现控制台输出是这个样子的:

  

  是的,mixin混入对象中声明了:如果是同名钩子函数将合并为一个数组,因此都被调用,但是混入对象的钩子将在自身实例钩子之前触发;

   值为对象的选项,例如methods,components等如果变量名和mixin混入对象的变量名发生冲突,将会以组件优先并进行递归合并,相当于组件数据直接覆盖了mixin中的同名数据;

   我们可以修改代码mixin.js和page1.vue

   mixin.js

  1. export const mixin={
  2. data(){
  3. return {
  4. number:1
  5. }
  6. },
  7. methods:{
  8. demo1(){
  9. console.log("mixin混入对象")
  10. }
  11. }
  12. }

  page1.vue

  1. <template>
  2. <div>page1的值是:{{number}}</div>
  3. </template>
  4.  
  5. <script>
  6. import {mixin} from "./mixin/mixin"
  7. export default {
  8. mixins:[mixin],
  9. data () {
  10. return {
  11. number:10
  12. }
  13. },
  14. mounted(){
  15. this.demo1();
  16. },
  17. methods:{
  18. demo1(){
  19. console.log("这里是page1");
  20. }
  21. }
  22. }
  23. </script>
  24.  
  25. <style scoped>
  26.  
  27. </style>

  运行代码我们可以很清晰的看到都是执行我们组件内的值;

  因为在vue中我们在实例中声明变量也是通过键值对的形式来声明的,其实也是一个对象;

  

   全局混入:

    全局混入我们只需要把mixin.js引入到main.js中,然后将mixin放入到Vue.mixin()方法中即可;

 

  1. // The Vue build version to load with the `import` command
  2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
  3. import Vue from 'vue'
  4. import App from './App'
  5. import router from './router.js'
  6. import mixin from "./mixin/mixin.js"
  7. Vue.config.productionTip = false
  8. Vue.mixin(mixin)
  9.  
  10. /* eslint-disable no-new */
  11. new Vue({
  12. el: '#app',
  13. router,
  14. components: { App },
  15. template: '<App/>'
  16. })

   是的,全局混入更为便捷,我们将不用在子组件声明,全局混入将会影响每一个组件的实例,使用的时候需要小心谨慎;这样全局混入之后,我们可以直接在组件中通过this.变量/方法来调用mixin混入对象的变量/方法;

  很多同学可能看到这里会有一些疑问,这不就跟Vuex差不多嘛,其实不是的:

  mixin混入对象和Vuex的区别:

    Vuex是状态共享管理,所以Vuex中的所有变量和方法都是可以读取和更改并相互影响的;

    mixin可以定义公用的变量或方法,但是mixin中的数据是不共享的,也就是每个组件中的mixin实例都是不一样的,都是单独存在的个体,不存在相互影响的;

    mixin混入对象值为函数的同名函数选项将会进行递归合并为数组,两个函数都会执行,只不过先执行mixin中的同名函数;

    mixin混入对象值为对象的同名对象将会进行替换,都优先执行组件内的同名对象,也就是组件内的同名对象将mixin混入对象的同名对象进行覆盖;

理解Vue.mixin,带你正确的偷懒的更多相关文章

  1. 手摸手带你理解Vue的Computed原理

    前言 computed 在 Vue 中是很常用的属性配置,它能够随着依赖属性的变化而变化,为我们带来很大便利.那么本文就来带大家全面理解 computed 的内部原理以及工作流程. 在这之前,希望你能 ...

  2. 手摸手带你理解Vue的Watch原理

    前言 watch 是由用户定义的数据监听,当监听的属性发生改变就会触发回调,这项配置在业务中是很常用.在面试时,也是必问知识点,一般会用作和 computed 进行比较. 那么本文就来带大家从源码理解 ...

  3. 深入理解 Vue 组件

    深入理解 Vue 组件 组件使用中的细节点 使用 is 属性,解决组件使用中的bug问题 <!DOCTYPE html> <html lang="en"> ...

  4. [前端开发]Vue mixin

    两个非常相似的组件,他们的基本功能是一样的,但他们之间又存在着足够的差异性,此时的你就像是来到了一个分岔路口:我是把它拆分成两个不同的组件呢?还是保留为一个组件,然后通过props传值来创造差异性从而 ...

  5. vue mixin执行覆盖

    https://cn.vuejs.org/v2/guide/mixins.html 完整代码 vue-option-overwrite-strategies vue 自带的mixin如果钩子函数重复会 ...

  6. vue.mixin与vue.extend

    vue.mixin 全局注册一个混合,影响注册之后所有创建的每个 Vue 实例.谨慎使用全局混合对象,因为会影响到每个单独创建的 Vue 实例(包括第三方模板).大多数情况下,只应当应用于自定义选项, ...

  7. Vue自带的过滤器

    gitHub地址:https://github.com/lily1010/vue_learn/tree/master/lesson05 一 过滤器写法 {{ message | Filter}} 二 ...

  8. 理解vue中的scope的使用

    理解vue中的scope的使用 我们都知道vue slot插槽可以传递任何属性或html元素,但是在调用组件的页面中我们可以使用 template scope="props"来获取 ...

  9. 理解Vue中的Render渲染函数

    理解Vue中的Render渲染函数 VUE一般使用template来创建HTML,然后在有的时候,我们需要使用javascript来创建html,这时候我们需要使用render函数.比如如下我想要实现 ...

随机推荐

  1. ASP.NET Core Web API

    1.简单介绍 ASP.NET Core Web API 是 ASP.NET Core MVC 的一个功能.ASP.NET Core MVC 包含了对 Web API 的支持.可以构建多种客户端的 HT ...

  2. 2019Hexo博客Next主题深度美化 打造一个炫酷博客(2)-奥怪的小栈

    219/8/1 更新 本文转载于:奥怪的小栈 这篇文章告诉你在搭建好博客后,面对网上千篇一律的美化教程怎么才能添加自己独特点,使人眼前一亮. 本站基于HEXO+Github搭建. 所以你需要准备好HE ...

  3. 【Fishing Master HDU - 6709 】【贪心】

    题意分析 题意:题目给出n条鱼,以及捕一条鱼所用的时间k,并给出煮每一条鱼的时间,问抓完并煮完所有鱼的最短时间. 附题目链接 思路: 1.捕第一条鱼的时间是不可避免的,煮每条鱼的时间也是不可避免的,这 ...

  4. 安装VMware Workstation时遇到Microsoft Runtime DLL安装程序未能完成安装

    解决:这时不要点确定.开始菜单运行输入‘%temp%’,在弹出的窗体中找到一个文件名中含‘{XXXXXXXXXXXXX}~setup'的文件夹,打开里面会看到有 xxx.msi的,运行就开始vmwar ...

  5. Nginx入门(二):镜像和容器

    0.docker常用命令 #镜像名 版本标签 镜像id 创建时间 镜像大小 REPOSITORY TAG IMAGE ID CREATED SIZE hello-world latest fce289 ...

  6. Enum与最佳単例设计

    1 枚举基础 自定义一个枚举类很简单, 不过类型关键字是 enum, 不是 class, 也不是 interface.public enum Action { UP, DOWN, LEFT, RIGH ...

  7. NLP(二十三)使用LSTM进行语言建模以预测最优词

    N元模型 预测要输入的连续词,比如 如果抽取两个连续的词汇,则称之为二元模型 准备工作 数据集使用 Alice in Wonderland 将初始数据提取N-grams import nltk imp ...

  8. dmg文件转iso格式

    1. 简介 dmg是MAC苹果机上的压缩镜像文件,相当于在Windows上常见的iso文件. dmg格式在苹果机上可以直接运行加载,在Windows平台上需要先转换为iso格式. 2. 转换工具 本文 ...

  9. 同步vmware虚拟机和主机的时间

    1. 打开虚拟机->设置 2. 选择选项标签页,选中VMware Tools,勾选“将客户机时间与主机同步”

  10. ccpc网赛 hdu6705 path(队列模拟 贪心

    http://acm.hdu.edu.cn/showproblem.php?pid=6705 这是比赛前8题过的人数第二少的题,于是就来补了,但感觉并不难啊..(怕不是签到难度 题意:给个图,给几条路 ...