混入(mixins) 是一种分发Vue 组件中可复用功能的非常灵活的方式

mixins主要用在以下两个方面:


当做完一个项目,想好好放松的时候,突然有新需求

为了不污染完美的构造函数,在构造函数外面定义一个mixins,这就是它的作用之一


一个项目中会经常会有公共的方法,这些公共的方法不想全都写在构造函数里

这时候就可以构造函数外面定义一个mixins,需要时就可以调用它


首先在构造函数外面定义为:

var countConsole = {
updated () {
console.log(this.count)
}
}

这里的updated是钩子函数,并不是自定义的函数

接下来需要在构造函数里注册这个mixins

注意这个mixins是一个数组,也就是可以定义多个mixins对象

mixins: [countConsole],

可以看到在控制台里依然可以输出累加的count数据。这个输出的操作是在构造函数外操作的

问题1:如果在构造函数里也定义了updated,那么哪个优先级更高呢

在mixins里做下改动

var countConsole = {
updated () {
console.log(this.count+”这里是mixins里的内容”)
}
}

在构造函数里做如下操作,加入钩子函数:

updated () {
console.log(”这里是原生里的内容”)
}

可以看到,mixins里的优先级是比构造函数的优先级高的

问题2:如果加入全局的updated的话,谁的优先级更高呢

首先引入vue

import Vue from 'vue'

再下来编写全局的updated:

Vue.mixin({
updated () {
console.log('这是全局内容')
}
})

可以看到优先级的排列是:

  1. 全局

  2. 局部mixin

  3. 构造函数

问题3:在mixins里定义一个methods,再在构造函数里定义一个methods

如果命名重复,会发生什么情况呢

首先们在DOM里加入触发按钮:

<button @click=”bar”>提交</button>
//在mixins里加入methods
methods: {
bar() {
console.log('hello World')
}
}

在构造函数里加入methods

methods: {
bar() {
console.log('hello meow')
}
}

会发现,在控制台里输出的是hello meow

如果methods里命名重复的话,只会执行构造函数里的函数,而不执行mixins里的函数

所以在mixins里定义函数时,不要与构造函数里的一样,这样会被构造函数里的函数覆盖的

原文链接:https://mp.weixin.qq.com/s/k35fObc85hK1lXLljSl20A

vue--mixins的更多相关文章

  1. Vue mixins(混入)

    建立一个公共组件,然后对该组件进行混入继承. 注意会走两个生命周期,谨慎使用 mixins混入,相当于生成new 组件:组件引用,相当与在父组件内开辟了一块单独的空间 mixins适用于,两个有非常相 ...

  2. _ 下划线 vue mixins 混入 变量前有下划线 变量不起作用

    _ 下划线 vue mixins 混入 变量前有下划线 变量不起作用

  3. VUE mixins(混入)

    mixins是在引入组件之后 将组件内部的内容如data等方法.method等属性与父组件相应内容进行合并 相当于在引入后 父组件的各种属性方法都被扩充了. 单纯组件引用:           父组件 ...

  4. vue mixins的使用

    官网传送 刚开始接触vue的时候,官网关于mixins的例子看了好几遍,发现还是不会用,包括vuex也是后来慢慢理解一点的,不过和vuex比起来.mixns还是很好理解,简单很多了 就我目前理解mix ...

  5. Vue mixins extends extend components

    mixins 调用方式: mixins: [mixin1, mixin2] 是对父组件的扩充,包括methods.components.directive等... 触发钩子函数时,先调用mixins的 ...

  6. vue mixins应用场景

    学习知识得在应用场景中去应用,这样才能真正学到东西,记忆也深刻,以后碰到类似的东西就会了. 1.在assets文件夹下创建一个js文件 // 创建一个需要混入的对象 export const mixi ...

  7. 十、vue mixins 的用法

    vue中mixins个人理解就是定义一些公用的比较常用的方法,类似我们vue中将一些常用的组件也会抽离出来做成一个公共组件一样,只不过vue中mixins是定义的是法或者计算属性,然后将其混入(合并) ...

  8. Vue mixins extend

    const mixins = { created () { console.log('mixins created') } } const mixins2 = { created () { conso ...

  9. vue mixins是什么及应用

    mixins是什么? 官网对此的解释比较文绉绉,通俗的理解很简单,就是提供功能抽象 如A,B,C ...Z等很多个页面用到同一个功能,此时的做法就应该把该功能抽象出来,mixins就是干这个的 当然, ...

  10. Vue Mixin 与微信小程序 Mixins 应用

    什么是Mixin(混入) Mixin是一种思想,用来实现代码高度可复用性,可以针对属性复制实现代码复用的想法进行一个扩展,就是混入(mixin).混入并不是复制一个完整的对象,而是从多个对象中复制出任 ...

随机推荐

  1. less is more,so 只记 less

    less + 文件名 1.Enter键 :向下翻一行 2.空格键 :向下翻一屏 3.j键 :想下翻一行 4.k键 :向上翻一行 5.f键 :向下翻一屏 6.b键 : 向上翻一屏 7.d键 :向下翻半屏 ...

  2. tensorflow(4)踩过的一些坑

    版本问题 1.1 版本的一个BUG ValueError: Variable rnn/basic_lstm_cell/weights already exists, disallowed. 结合这个文 ...

  3. 消息中间件解决方案JMS

    1. JMS入门 1.1消息中间件 1.1.1品优购系统模块调用关系分析 我们现在讲品优购已经完成的功能模块梳理如下: 我们已经完成了5个web模块和4个服务模块.其中运营商后台的调用关系最多,用到了 ...

  4. Git知识

    git最小化配置: 配置user.name 和 user.email git config --global user.name 'your_name' git config --global use ...

  5. 阿里云mysql安装配置(CentOS 7.3 64)

    自建目录并且加载yum资源mysql 安装 回车之后竟然出现不可以的情况(原因是原来的镜像里面默认装好了mysql5.7) 然后只能尝试跳过密码登录 #vim /etc/my.cnf 在文档内搜索my ...

  6. 北京大学Cousera学习笔记--7-计算导论与C语言基础--基本数据类型&变量&常量

    1.整形数据 1.基本型(int 4B).短整型(short 2B).长整型(long 4B)  VC环境下 sizeof运算符用于计算某种类型的对象在内存中所占的字节数 ,用法:size(int) ...

  7. winsock I/O模型的分析

    几种winsock I/O模型的分析 套接字是通信的基础,是支持网络协议数据通信的基本接口.Winsocket 提供了一些有趣的I/O模型,有助于应用程序通过一种“异步”方式,一次对一个或者多个套接字 ...

  8. 编程规范(初尝ES6与webpack)

    //针对ES6规范(第1-5条)start1.块级作用域let/const取代var:在let和const之间,建议优先使用const,尤其是在全局环境,不应该设置变量,只应设置常量. 2.解构赋值1 ...

  9. Python伊始——From Boring to Amazing

    先来谈一下关于Python编程语言的浅薄认知,“一门编程课,仅此而已”这是我几个月前对这门应用技术的认识. 如今看来,却不只是“仅此而已”,作为今年年初被加入计算机二级考试科目的这门技术,或许并不是它 ...

  10. 【Spark-SQL学习之二】 SparkSQL DataFrame创建和储存

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...