Vue.use()的作用及原理
點擊打開視頻講解
在Vue中引入使用第三方庫通常我們都會采用import的形式引入進來
但是有的組件在引入之后又做了Vue.use()操作
有的組件引入進來又進行了Vue.prototype.$axios = axios
那么它們之間有什么聯系呢?
例如:Vue.use(VueRouter)、Vue.use(MintUI),但是用 axios時,就不需要用 Vue.use(axios),就能直接使用,那這是為什么吶?
因為 axios 沒有 install,
Vue.use是什么?
官方對 Vue.use() 方法的說明:通過全域方法 Vue.use() 使用插件,Vue.use 會自動阻止多次注冊相同插件,它需要在你呼叫 new Vue() 啟動應用之前完成,Vue.use() 方法至少傳入一個引數,該引數型別必須是 Object 或 Function,如果是 Object 那么這個 Object 需要定義一個 install 方法,如果是 Function 那么這個函式就被當做 install 方法,在 Vue.use() 執行時 install 會默認執行,當 install 執行時第一個引數就是 Vue,其他引數是 Vue.use() 執行時傳入的其他引數,就是說使用它之后呼叫的是該組件的install 方法,
Vue.use()什么時候使用?
ElementUI、VueRouter等官方插件的使用
在vue官方社區中提供了一系列輔助開發的插件,其中就有很多插件具有install方法,
比如ElementUI和VueRouter,我們使用Vue.use()進行引入,
import Vue from 'vue'
import VueRouter from 'vue-router';
import Element from 'element-ui'
Vue.use(VueRouter);
Vue.use(Element);
自定義插件,并提供install方法
除了使用官方的插件,我們也可以自定義一些含有install方法的插件或函式插件
src\main.js
import Vue from 'vue'
import App from './App.vue'
//引入ElementUI組件庫
import ElementUI from 'element-ui';
//引入ElementUI全部樣式
import 'element-ui/lib/theme-chalk/index.css';
import {Plugin1,Plugin2} from './plugins/plugins.js'
Vue.config.productionTip = false
//使用ElementUI
Vue.use(ElementUI)
Vue.use(Plugin1,'引數1')
Vue.use(Plugin2,'引數2')
new Vue({
render: h => h(App),
}).$mount('#app')
src\plugins\plugins.js
// 物件形式
const Plugin1 = {
install(Vue,b){
console.log('Plugin1 第一個引數:',Vue)
console.log('Plugin1 第二個引數:',b)
}
}
// 函式形式
function Plugin2(Vue,b){
console.log('Plugin2 第一個引數:',Vue)
console.log('Plugin2 第二個引數:',b)
}
export{ Plugin1, Plugin2 }
效果:

Vue.prototype作用
vue.prototype是一種注冊全域變數的方式,使用vue.prototype的變數可以全域訪問,
最典型的例子就是axios,
import axios from 'axios';
Vue.prototype.$http = axios;
注冊了axios之后就能在專案的位置使用了,使用的方法:
呼叫this.$http進行訪問,
實際上我們還要注意,使用Vue.prototype注冊的全域變數前面都要加上$符號,這是一種規范,主要是為了防止命名沖突,
Vue.use()和Vue.prototype的區別
Vue.use()用于注冊具有install方法的變數,注冊后install函式會自動呼叫,使得install的具體變數能夠全域使用,包括全域變數,全域標簽等等,
而Vue.prototype就是一個注冊全域變數的方法,注冊的全域的變數以$開頭,呼叫this方法呼叫,
Vue.use()總結
通過以上分析我們可以知道,在我們以后撰寫插件的時候可以有兩種方式,
一種是將這個插件的邏輯封裝成一個物件,最后將在 install 撰寫業務代碼暴露給 Vue 物件,這樣做的好處是可以添加任意引數在這個物件上方便將 install 函式封裝得更加精簡,可拓展性也比較高,推薦使用object;
還有一種則是將所有邏輯都撰寫成一個函式暴露給 Vue,
其實兩種方法原理都一樣,無非第二種就是將這個插件直接當成 install 函式來處理,
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/501539.html
標籤:其他
