本文主要介紹了Vue官方文檔梳理之全局配置,分享給大家,也給自己留個(gè)筆記。具體如下:
optionMergeStrategies
用于自定義選項(xiàng)的合并策略,Vue已經(jīng)預(yù)定義了一些自己配置項(xiàng)的合并策略,如下圖所示。
比如props、methods、computed就是同一個(gè)策略:子配置項(xiàng)會(huì)覆蓋父級(jí)配置項(xiàng)。源碼如下:
var strats = config.optionMergeStrategies; strats.props = strats.methods = strats.computed = 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 };
什么時(shí)候才會(huì)用到這些配置的合并規(guī)則呢?查閱源碼,發(fā)現(xiàn)只要調(diào)用mergeOptions時(shí),就會(huì)用到上面的策略??偨Y(jié)下來有以下幾種場景:
單獨(dú)使用一個(gè)時(shí),也會(huì)觸發(fā)合并規(guī)則,但是只會(huì)有child包含配置項(xiàng),所以不需要合并。只有當(dāng)多個(gè)一起使用時(shí),比如 Vue.compeont 和 extends 、mixins 配置項(xiàng)一起使用,這個(gè)時(shí)候就parent和child都會(huì)有相同的配置項(xiàng),這時(shí)候也才有所謂的合并,舉個(gè)完整的例子來說明上述的場景。
Vue.config.optionMergeStrategies['customOption'] = function (toVal, fromVal) { console.log(toVal, fromVal) if (!toVal) return fromVal if (!fromVal) return toVal // toVal 和 fromVal 同時(shí)存在,表明此時(shí)parent和child都包含配置型 return toVal + '&' + fromVal } Vue.extend({ customOption: 'Vue.extend' }) Vue.component('custom', { customOption: 'Vue.component' }) var vm = new Vue({ customOption: 'newVue', extends: { customOption: 'extends' }, mixins: [{ customOption: 'mixins' }] }) console.log(vm.$options.customOption)
控制臺(tái)打印如下:
按順序解釋如下:
devtools
離線下載chrome 擴(kuò)展地址(不需要梯子):https://www.crx4chrome.com/crx/11903/
把下載的文件拖到擴(kuò)展程序頁面即可完成安裝。
errorHandler
Vue 涉及到執(zhí)行用戶配置的地方都放在 try catch 中,因此即使你 throw 拋出錯(cuò)誤,整個(gè)實(shí)例也不會(huì)掛。
Vue.config.errorHandler = function (err, vm, info) { console.log(arguments) } new Vue({ created: function () { throw "error msg" } }) // ["error msg", Vue$3, "created hook"]
ignoredElements
首先要理解忽略的到底是什么?是元素本身還是包括元素里的內(nèi)容(就像v-pre一樣),首先要知道這個(gè)配置的背景,官網(wǎng)舉了Web Components APIs(以下簡稱WCA)的例子,WCA和Vue.component一樣,也可以自定義元素,不過這個(gè)目前還是個(gè)草案。那么對(duì)于Vue來講,元素就可以分為:HTML原生元素,Vue自定義元素,WCA自定義元素。那么對(duì)于一個(gè)元素,Vue的判斷順序:原生 > Vue自定義 > ignoredElements > 無法識(shí)別,對(duì)于無法識(shí)別的Vue會(huì)假定你可能把Vue自己定義元素拼錯(cuò)了,因此會(huì)發(fā)出Unknown custom element的警告。另外:
performance(2.2.0+)
只能在開發(fā)版上使用。caniuse上查詢 performance 可知主流瀏覽器都已經(jīng)支持,這個(gè)可以用于分析Vue組件在不同階段中花費(fèi)的時(shí)間,進(jìn)而知道哪里可以優(yōu)化。查看源碼,發(fā)現(xiàn)在以下階段加上了performance.measure。
比如在谷歌瀏覽器中查看自定義組件Vue.component('my-component')的各個(gè)階段花費(fèi)的時(shí)間:
在 IE11 中查看
productionTip(2.2.0+)
對(duì)于開發(fā)版本,會(huì)默認(rèn)向控制臺(tái)打?。?/p>
設(shè)置為false就不再顯示。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com