您好,登錄后才能下訂單哦!
這篇文章主要介紹了Vue中的Vue.prototype如何用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Vue中的Vue.prototype如何用文章都會有所收獲,下面我們一起來看看吧。
在main.js中添加一個變量到 Vue.prototype
Vue.prototype.$appName = 'My App'
這樣 $appName 就在所有的 Vue 實例中可用了,甚至在實例被創建之前就可以
new Vue({ beforeCreate: function () { console.log(this.$appName) } })
控制臺會打印出 My App,就這么簡單!
為什么 appName 要以 開頭?這很重要嗎?這里沒有什么魔法。 開頭? 這很重要嗎? 這里沒有什么魔法。開頭?這很重要嗎?這里沒有什么魔法。 是在 Vue 所有實例中都可用的 property 的一個簡單約定。這樣做會避免和已被定義的數據、方法、計算屬性產生沖突。
如果我們設置:
Vue.prototype.appName = 'My App'
那么如下的代碼輸出什么:
new Vue({ data: { // 啊哦,`appName` 也是一個我們定義的實例 property 名! appName: 'The name of some other app' }, beforeCreate: function () { console.log(this.appName) }, created: function () { console.log(this.appName) } })
日志中會先出現 "My App",然后出現 "The name of some other app",因為 this.appName 在實例被創建之后被 data 覆寫了。我們通過 為實例property設置作用域來避免這種事情發生。你還可以根據你的喜好使用自己的約定,諸如為實例 property 設置作用域來避免這種事情發生。 你還可以根據你的喜好使用自己的約定,諸如為實例property設置作用域來避免這種事情發生。你還可以根據你的喜好使用自己的約定,諸如_appName 或 ΩappName,來避免和插件或未來的插件相沖突。
每個組件都是一個vue實例,Vue.prototype加一個變量,只是給每個組件加了一個屬性,這個屬性的值并不具有全局性。
比如以下例子:
// main.js import Vue from 'vue' import App from './App' import router from './router' import store from './store' Vue.config.productionTip = false Vue.prototype.$appName = 'main' new Vue({ el: '#app', store, router, components: { App }, template: '<App/>', }) // 給所有組件注冊了一個屬性 $appName,賦予初始值 'main' ,所有組件都可以用 this.$appName 訪問此變量; // 如果組件中沒有賦值,初始值都是'main'
// home.vue <template> <div> <div @click="changeName">change name</div> <div @click="gotoTest2">goto test2</div> </div> </template> <script> export default { methods:{ changeName(){ this.$appName = "test1" }, gotoTest2(){ this.$router.push('/about') } } } </script>
// about.vue <template> <div> <div>{{this.$appName}} in test2</div> </div> </template>
點擊 home 中的 change name 再跳轉about,about里面還是顯示 main in test2
如果要實現全局變量的功能,需要把屬性變為引用類型
Vue.prototype.$appName = { name: 'main' }
后面使用 this.$appName.name 改變和引用相應的值
這進入 about 后顯示 test1 in test2
在 JavaScript 中一個原型的方法會獲得該實例的上下文,也就是說可以使用 this 訪問:數據、計算屬性、方法或其它任何定義在實例上的東西。
讓我們將其用在一個名為 $reverseText 的方法上:
// main.js Vue.prototype.$reverseText = function (propertyName) { this[propertyName] = this[propertyName] .split('') .reverse() .join('') }
// 相應組件 <script> export default { data() { return{ message: 'Hello' } }, created() { console.log(this.message) // => "Hello" this.$reverseText('message') console.log(this.message) // => "olleH" } } </script>
npm install vue-axios --save npm install qs.js --save //它的作用是能把json格式的直接轉成data所需的格式
// mian.js import Vue from 'vue' import axios from 'axios' import qs from 'qs' Vue.prototype.$axios = axios //全局注冊,使用方法為:this.$axios Vue.prototype.qs = qs //全局注冊,使用方法為:this.qs // 相應組件 <script> export default{ data(){ return{ userId:666, token:'', } }, created(){ this.$axios({ method:'post', url:'api', data:this.qs.stringify({ //這里是發送給后臺的數據 userId:this.userId, token:this.token, }) }).then((response) =>{ //這里使用了ES6的語法 console.log(response) //請求成功返回的數據 }).catch((error) =>{ console.log(error) //請求失敗返回的數據 }) } } </script>
在多個地方都需要使用但不想污染全局作用域的情況下,這樣定義,在每個 Vue 實例中都可用。
參考:https://cn.vuejs.org/v2/cookbook/adding-instance-properties.html
$ 表示這是一個在 Vue 所有實例中都可用的屬性
常用于方法、變量等
import echarts from 'echarts' Vue.prototype.$echarts = echarts
全局注冊組件,
第一個參數是調用組件時寫的組件名
第二個參數是引入組件時寫的名稱
可用于注冊自定義組件
import myLoading from 'base/loading' Vue.component('myLoading',myLoading);
同樣是全局注冊,和component的區別是接收的參數必須有install方法
常用于注冊第三方插件
import ElementUI from 'element-ui'; Vue.use(ElementUI);
關于“Vue中的Vue.prototype如何用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Vue中的Vue.prototype如何用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。