Vue官方文档梳理之全局配置
本文主要介绍了Vue官方文档梳理之全局配置,分享给大家,也给自己留个笔记。具体如下
optionMergeStrategies
用于自定义选项的合并策略,Vue已经预定义了一些自己配置项的合并策略,如下图所示。
比如props、methods、puted就是同一个策略子配置项会覆盖父级配置项。源码如下
var strats = config.optionMergeStrategies; strats.props = strats.methods = strats.puted = function (parentVal, childVal) { if (!childVal) { return Object.create(parentVal || null) } if (!parentVal) { return childVal } var ret = Object.create(null); extend(ret, parentVal); extend(ret, childVal); return ret };
什么时候才会用到这些配置的合并规则呢?查阅源码,发现只要调用mergeOptions时,就会用到上面的策略。下来有以下几种场景
- 使用了 Vue.mixin 或 mixins 配置项
- 使用了 Vue.extend 或 extends 配置项或Vue.ponent(背后实际上是调用了Vue.extend)
- new Vue() 或 new Vue.extend()
单独使用一个时,也会触发合并规则,只会有child包含配置项,所以不需要合并。只有当多个一起使用时,比如 Vue.peont 和 extends 、mixins 配置项一起使用,这个时候就parent和child都会有相同的配置项,这时候也才有所谓的合并,举个完整的例子来说明上述的场景。
Vue.config.optionMergeStrategies['customOption'] = function (toVal, fromVal) { console.log(toVal, fromVal) if (!toVal) return fromVal if (!fromVal) return toVal // toVal 和 fromVal 存在,表明此时parent和child都包含配置型 return toVal + '&' + fromVal } Vue.extend({ customOption: 'Vue.extend' }) Vue.ponent('custom', { customOption: 'Vue.ponent' }) var vm = new Vue({ customOption: 'newVue', extends: { customOption: 'extends' }, mixins: [{ customOption: 'mixins' }] }) console.log(vm.$options.customOption)
控制台打印如下
按顺序解释如下
- undefined "Vue.extend"合并 Vue.options 和 extendOptions
- undefined "Vue.ponent"合并 Vue.options 和 extendOptions
- undefined "extends"extends配置项合并先于mixins,此时合并的是 Vue.options 和extends配置,toVal是undefined
- extends mixins完成了extends合并,接着就是mixins,此时 Vue.options 上已经包含了extends的配置项, toVal 是extends,fromVal就是mixins。最终合并后的值extends&mixins
- extends&mixins newVue完成了extends和mixins后,最终合并vm.constructor和实例的options
- extends&mixins&newVue最终合并后的 customOption 的选项值
devtools
离线下载chrome 扩展地址(不需要梯子)
把下载的文件拖到扩展程序页面即可完成安装。
errorHandler
Vue 涉及到执行用户配置的地方都放在 try catch 中,即使你 throw 抛出错误,整个实例也不会挂。
Vue.config.errorHandler = function (err, vm, info) { console.log(arguments) } new Vue({ created: function () { throw "error msg" } }) // ["error msg", Vue$3, "created hook"]
ignoredElements
要理解忽略的到底是什么?是元素本身还是包括元素里的内容(就像v-pre一样),要知道这个配置的背景,官网举了Web Components APIs(以下简称WCA)的例子,WCA和Vue.ponent一样,也可以自定义元素,不过这个目前还是个草案。那么对于Vue来讲,元素就可以分为HTML原生元素,Vue自定义元素,WCA自定义元素。那么对于一个元素,Vue的判断顺序原生 > Vue自定义 > ignoredElements > 无法识别,对于无法识别的Vue会假定你可能把Vue自己定义元素拼错了,会发出Unknown custom element的警告。
- Vue定义和HTML标签同名的元素是无效的,比如定义Vue.poent('header',{})
- ignoredElements包含Vue定义的元素是无效的
- WCA自定义元素可以被构建虚拟dom
performance(2.2.0+)
只能在开发版上使用。caniuse上查询 performance 可知主流浏览器都已经支持,这个可以用于分析Vue组件在不同阶段中花费的时间,进而知道哪里可以优化。查看源码,发现在以下阶段加上了performance.measure。
- performance.measure((组件名+ " render"), startTag, endTag);
- performance.measure((组件名+ " patch"), startTag, endTag);
- performance.measure((组件名 + " init"), startTag, endTag);
- performance.measure(((组件名 + " pile"), 'pile', 'pile end');
比如在谷歌浏览器中查看自定义组件Vue.ponent('my-ponent')的各个阶段花费的时间
在 IE11 中查看
productionTip(2.2.0+)
对于开发版本,会默认向控制台打印
设置为false就不再显示。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程