Vue如何通過Vue.prototype定義原型屬性實(shí)現(xiàn)全局變量
Vue通過Vue.prototype定義原型屬性實(shí)現(xiàn)全局變量
如果需要設(shè)置全局變量,但不想污染全局作用域。
這種情況下
可以通過在main.js中,Vue實(shí)例化的代碼里通過添加了原型屬性實(shí)現(xiàn)全局變量,使其在每個(gè) Vue 的實(shí)例中可用。
Vue.prototype.$appName = 'My App'
這樣 $ appName 就在所有的 Vue 實(shí)例中可用了,甚至在實(shí)例被創(chuàng)建之前就可以。
如果我們運(yùn)行下述代碼
則控制臺會打印出 My App。
new Vue({ beforeCreate: function () { console.log(this.$appName) } })
- 提問:上述代碼中,為什么 appName 要以 $ 開頭呢?
- 回答:$ 是在 Vue 所有實(shí)例中都可用的屬性的一個(gè)簡單約定。這樣做會避免和已被定義的數(shù)據(jù)、方法、計(jì)算屬性產(chǎn)生沖突。
假如我們在main.js中通過如下方式定義原型屬性
運(yùn)行下述代碼,則控制臺會打印什么呢?
Vue.prototype.appName = 'My App' new Vue({ data: { appName: 'The name of some other app' }, beforeCreate: function () { //父類中的屬性 console.log(this.appName) }, created: function () { //子類重寫的屬性 console.log(this.appName) } })
控制臺日志中會先出現(xiàn) “My App”
然后出現(xiàn) “The name of some other app”
因?yàn)?this.appName 在實(shí)例被創(chuàng)建之后被 data 覆寫了
我們通過 $ 為實(shí)例屬性設(shè)置作用域來避免這種事情發(fā)生。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue實(shí)現(xiàn)兄弟組件之間跳轉(zhuǎn)指定tab標(biāo)簽頁
這篇文章主要介紹了vue實(shí)現(xiàn)兄弟組件之間跳轉(zhuǎn)指定tab標(biāo)簽頁,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Vue3+Element?Plus實(shí)現(xiàn)動態(tài)標(biāo)簽頁以及右鍵菜單功能
這篇文章主要給大家介紹了關(guān)于Vue3+Element?Plus實(shí)現(xiàn)動態(tài)標(biāo)簽頁以及右鍵菜單功能的相關(guān)資料,Vue?3和Element?Plus提供了一種簡單的方法來實(shí)現(xiàn)側(cè)邊菜單欄與標(biāo)簽頁之間的聯(lián)動,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09Vue實(shí)現(xiàn)路由跳轉(zhuǎn)的3種方式超詳細(xì)分解
Vue.js是一款流行的前端JavaScript框架,它提供了多種方式來實(shí)現(xiàn)路由跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)路由跳轉(zhuǎn)的3種方式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12vue?draggable組件實(shí)現(xiàn)拖拽及點(diǎn)擊無效問題的解決
這篇文章主要介紹了vue?draggable組件實(shí)現(xiàn)拖拽及點(diǎn)擊無效問題的解決,只需要在設(shè)置handle屬性就可以了,.defaultTypeTag 是要拖拽的塊的類名,要注意的是需要做點(diǎn)擊事件的項(xiàng)不能包含在這個(gè)類名里面,不然會無法觸發(fā)點(diǎn)擊事件,詳細(xì)解決辦法跟隨小編一起學(xué)習(xí)吧2022-05-05vue單個(gè)元素綁定多個(gè)事件問題(例如點(diǎn)擊綁定多個(gè)事件方法)
這篇文章主要介紹了vue單個(gè)元素綁定多個(gè)事件問題(例如點(diǎn)擊綁定多個(gè)事件方法),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04