真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

淺談Vue.use的使用

vue.use(plugin, arguments) 語(yǔ)法

創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括東豐網(wǎng)站建設(shè)、東豐網(wǎng)站制作、東豐網(wǎng)頁(yè)制作以及東豐網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,東豐網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到東豐省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

參數(shù):plugin(Function | Object)

用法:

如果vue安裝的組件類型必須為Function或者是Object

如果是個(gè)對(duì)象,必須提供install方法

如果是一個(gè)函數(shù),會(huì)被直接當(dāng)作install函數(shù)執(zhí)行

install函數(shù)接受參數(shù),默認(rèn)第一個(gè)參數(shù)為Vue,其后參數(shù)為注冊(cè)組件時(shí)傳入的arguments

先舉個(gè)?

我們先來(lái)看一個(gè)簡(jiǎn)單的事例

首先我使用官方腳手架新建一個(gè)項(xiàng)目vue init webpack vue-demo

然后我創(chuàng)建兩個(gè)文件index.js plugins.js.

我將這兩個(gè)文件放置在src/classes/vue-use目錄下

接下來(lái)對(duì)這兩個(gè)文件進(jìn)行編寫

// 文件: src/classes/vue-use/plugins.js

const Plugin1 = {
  install(a, b, c) {
    console.log('Plugin1 第一個(gè)參數(shù):', a);
    console.log('Plugin1 第二個(gè)參數(shù):', b);
    console.log('Plugin1 第三個(gè)參數(shù):', c);
  },
};

function Plugin2(a, b, c) {
  console.log('Plugin2 第一個(gè)參數(shù):', a);
  console.log('Plugin2 第二個(gè)參數(shù):', b);
  console.log('Plugin2 第三個(gè)參數(shù):', c);
}

export { Plugin1, Plugin2 };

// 文件: src/classes/vue-use/index.js

import Vue from 'vue';

import { Plugin1, Plugin2 } from './plugins';

Vue.use(Plugin1, '參數(shù)1', '參數(shù)2');
Vue.use(Plugin2, '參數(shù)A', '參數(shù)B');

然后我們?cè)谌肟谖募ain.js引用這段代碼

// 文件: src/main.js

import Vue from 'vue';

import '@/classes/vue-use';
import App from './App';
import router from './router';

Vue.config.productionTip = false;

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  render: h => h(App),
});

此時(shí)我們執(zhí)行npm run dev打開(kāi)8080端口開(kāi)啟開(kāi)發(fā)調(diào)試工具可以看到控制臺(tái)輸出以下信息

淺談Vue.use的使用

...]

從中可以發(fā)現(xiàn)我們?cè)趐lugin1中的install方法編寫的三個(gè)console都打印出來(lái),第一個(gè)打印出來(lái)的是Vue對(duì)象,第二個(gè)跟第三個(gè)是我們傳入的兩個(gè)參數(shù)。

而plugin2沒(méi)有install方法,它本身就是一個(gè)方法,也能打印三個(gè)參數(shù),第一個(gè)是Vue對(duì)象,第二個(gè)跟第三個(gè)也是我們傳入的兩個(gè)參數(shù)。

那么現(xiàn)在我們是不是大概對(duì)Vue.use有一個(gè)模糊的猜想~

分析源碼

好我們還是不要猜想,直接上源碼

// Vue源碼文件路徑:src/core/global-api/use.js

import { toArray } from '../util/index'

export function initUse (Vue: GlobalAPI) {
 Vue.use = function (plugin: Function | Object) {
  const installedPlugins = (this._installedPlugins || (this._installedPlugins = []))
  if (installedPlugins.indexOf(plugin) > -1) {
   return this
  }

  // additional parameters
  const args = toArray(arguments, 1)
  args.unshift(this)
  if (typeof plugin.install === 'function') {
   plugin.install.apply(plugin, args)
  } else if (typeof plugin === 'function') {
   plugin.apply(null, args)
  }
  installedPlugins.push(plugin)
  return this
 }
}

從源碼中我們可以發(fā)現(xiàn)vue首先判斷這個(gè)插件是否被注冊(cè)過(guò),不允許重復(fù)注冊(cè)。

并且接收的plugin參數(shù)的限制是Function | Object兩種類型。

對(duì)于這兩種類型有不同的處理。

首先將我們傳入的參數(shù)整理成數(shù)組 => const args = toArray(arguments, 1)。

(toArray源碼)

// Vue源碼文件路徑:src/core/shared/util.js

export function toArray (list: any, start?: number): Array {
 start = start || 0
 let i = list.length - start
 const ret: Array = new Array(i)
 while (i--) {
  ret[i] = list[i + start]
 }
 return ret
}

再將Vue對(duì)象添加到這個(gè)數(shù)組的起始位置args.unshift(this),這里的this 指向Vue對(duì)象

如果我們傳入的plugin(Vue.use的第一個(gè)參數(shù))的install是一個(gè)方法。也就是說(shuō)如果我們傳入一個(gè)對(duì)象,對(duì)象中包含install方法,那么我們就調(diào)用這個(gè)plugin的install方法并將整理好的數(shù)組當(dāng)成參數(shù)傳入install方法中。 => plugin.install.apply(plugin, args)
如果我們傳入的plugin就是一個(gè)函數(shù),那么我們就直接調(diào)用這個(gè)函數(shù)并將整理好的數(shù)組當(dāng)成參數(shù)傳入。 => plugin.apply(null, args)
之后給這個(gè)插件添加至已經(jīng)添加過(guò)的插件數(shù)組中,標(biāo)示已經(jīng)注冊(cè)過(guò) => installedPlugins.push(plugin)
最后返回Vue對(duì)象。

小結(jié)

通過(guò)以上分析我們可以知道,在我們以后編寫插件的時(shí)候可以有兩種方式。

一種是將這個(gè)插件的邏輯封裝成一個(gè)對(duì)象最后將最后在install編寫業(yè)務(wù)代碼暴露給Vue對(duì)象。這樣做的好處是可以添加任意參數(shù)在這個(gè)對(duì)象上方便將install函數(shù)封裝得更加精簡(jiǎn),可拓展性也比較高。

還有一種則是將所有邏輯都編寫成一個(gè)函數(shù)暴露給Vue。

其實(shí)兩種方法原理都一樣,無(wú)非第二種就是將這個(gè)插件直接當(dāng)成install函數(shù)來(lái)處理。

個(gè)人覺(jué)得第一種方式比較合理。

舉個(gè)?

export const Plugin = {
  install(Vue) {
    Vue.component...
    Vue.mixins...
    Vue...
    // 我們也可以在install里面執(zhí)行其他函數(shù),Vue會(huì)將this指向我們的插件
    console.log(this) // {install: ...,utils: ...}
    this.utils(Vue)  // 執(zhí)行utils函數(shù)
    console.log(this.COUNT) // 0
  },
  utils(Vue) {
    Vue...
    console.log(Vue) // Vue
  },
  COUNT: 0  
}
// 我們可以在這個(gè)對(duì)象上添加參數(shù),最終Vue只會(huì)執(zhí)行install方法,而其他方法可以作為封裝install方法的輔助函數(shù)

const test = 'test'
export function Plugin2(Vue) {
  Vue...
  console.log(test) // 'test'
  // 注意如果插件編寫成函數(shù)形式,那么Vue只會(huì)把this指向null,并不會(huì)指向這個(gè)函數(shù)
  console.log(this) // null
}
// 這種方式我們只能在一個(gè)函數(shù)中編寫插件邏輯,可封裝性就不是那么強(qiáng)了

小弟不才,對(duì)vue源碼的理解暫且到這。歡迎大佬們多指教~

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


新聞標(biāo)題:淺談Vue.use的使用
本文地址:http://weahome.cn/article/gsiedh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部