vue--mixins
混入(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('这是全局内容')
}
})
可以看到优先级的排列是:
全局
局部mixin
构造函数
问题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的更多相关文章
- Vue mixins(混入)
建立一个公共组件,然后对该组件进行混入继承. 注意会走两个生命周期,谨慎使用 mixins混入,相当于生成new 组件:组件引用,相当与在父组件内开辟了一块单独的空间 mixins适用于,两个有非常相 ...
- _ 下划线 vue mixins 混入 变量前有下划线 变量不起作用
_ 下划线 vue mixins 混入 变量前有下划线 变量不起作用
- VUE mixins(混入)
mixins是在引入组件之后 将组件内部的内容如data等方法.method等属性与父组件相应内容进行合并 相当于在引入后 父组件的各种属性方法都被扩充了. 单纯组件引用: 父组件 ...
- vue mixins的使用
官网传送 刚开始接触vue的时候,官网关于mixins的例子看了好几遍,发现还是不会用,包括vuex也是后来慢慢理解一点的,不过和vuex比起来.mixns还是很好理解,简单很多了 就我目前理解mix ...
- Vue mixins extends extend components
mixins 调用方式: mixins: [mixin1, mixin2] 是对父组件的扩充,包括methods.components.directive等... 触发钩子函数时,先调用mixins的 ...
- vue mixins应用场景
学习知识得在应用场景中去应用,这样才能真正学到东西,记忆也深刻,以后碰到类似的东西就会了. 1.在assets文件夹下创建一个js文件 // 创建一个需要混入的对象 export const mixi ...
- 十、vue mixins 的用法
vue中mixins个人理解就是定义一些公用的比较常用的方法,类似我们vue中将一些常用的组件也会抽离出来做成一个公共组件一样,只不过vue中mixins是定义的是法或者计算属性,然后将其混入(合并) ...
- Vue mixins extend
const mixins = { created () { console.log('mixins created') } } const mixins2 = { created () { conso ...
- vue mixins是什么及应用
mixins是什么? 官网对此的解释比较文绉绉,通俗的理解很简单,就是提供功能抽象 如A,B,C ...Z等很多个页面用到同一个功能,此时的做法就应该把该功能抽象出来,mixins就是干这个的 当然, ...
- Vue Mixin 与微信小程序 Mixins 应用
什么是Mixin(混入) Mixin是一种思想,用来实现代码高度可复用性,可以针对属性复制实现代码复用的想法进行一个扩展,就是混入(mixin).混入并不是复制一个完整的对象,而是从多个对象中复制出任 ...
随机推荐
- 学号 20175313 《实验三 敏捷开发与XP实践》实验报告
目录 实验三 敏捷开发与XP实践 一.实验内容 二.实验步骤 四.心得体会 五.码云链接 六.参考资料 实验三 敏捷开发与XP实践 一.实验内容 (1)编码标准 在IDEA中使用工具(Code-> ...
- python基础-->流程控制-->分支结构-->单项分支-->双向分支
# ###流程控制 ''' 流程:代码执行过程 流程控制:对代码执行过程的管控 顺序结构:代码默认从上到下依次执行 分支结构:对代码执行过程的管控 循环机构: while for ..in.... 分 ...
- 2019.4.14 python基础30
前面学习的变量,数据类型(整型,浮点数,布尔),序列(字符串,列表,元祖,字典,集合) ,可以看做是数据的组织方式.数据可以看做是“砖块”! 流程控制语句是代码的组织方式,可以看做是“混凝土” 一个完 ...
- Jackson流式API
public class JacksonTester { public static void main(String args[]){ JacksonTester tester = new ...
- Oracle 12C 补丁升级
升级步骤 Oracle 12.2.0.1升级至12.2.0.1.190115 1.阅读readme文件 2.检查更新opatch 3.备份程序 4.使用opatchauto工具进行数据库升级 5.打O ...
- mipush ionic3 线上push
<dict> <key>aps-environment</key> <string>production</string> </dic ...
- windows 下面安装make
1.前面文章中已经提到了wingw32的安装,安装好之后设置相应环境变量.2.打开cmd,输入 mingw-get install mingw32-make,会进行安装.3.输入 mingw32-ma ...
- spring boot集成aop实现日志记录
1.pom依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...
- Qt QLineEdit 漂亮的搜索框 && 密码模式 && 格式化输入 && 提示文字 && 选择内容并移动 && 清除全部输入
先上一个漂亮的搜索框效果图, 输入搜索文本效果, 点击搜索图标效果: //实现代码 void MainWindow::iniLineEdit() { ui->lineEdit->setPl ...
- 2017UGUI之slider
不让鼠标控制slider的滑动: 鼠标之所以可以控制滑动是因为slider具有interactable这个属性(下图红色的箭头的地方):如果取消了这个属性的运行的时候就不能滑动了.如果要代码去控制这个 ...