您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“vue-router初始化的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“vue-router初始化的示例分析”這篇文章吧。
vue router 的初始化使用步驟
我們首先來(lái)看 vue-router 的使用步驟,然后再分別去看各個(gè)步驟都發(fā)生了什么。
使用 vue-router 需要經(jīng)過(guò)一下幾個(gè)步驟:
引入 vue-router:
import VueRouter from 'vue-router';
利用 vue 的插件機(jī)制,加載 vue-router:
Vue.use(VueRouter);
實(shí)例化 VueRouter:
const router = new VueRouter({ routes })
實(shí)例化 Vue:
const app = new Vue({ router }).$mount('#app');
Vue 的插件機(jī)制
vue 提供了一個(gè) use 方法,來(lái)加載插件:
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; }
該方法首先檢查插件是否已經(jīng)加載,如果已經(jīng)加載,直接返回 this。
如果沒(méi)有加載過(guò),會(huì)取所有的參數(shù),并將 this 放在第一個(gè)。優(yōu)先執(zhí)行 plugin.install 方法,若不能執(zhí)行,則直接執(zhí)行 plugin 自身。
最后將 plugin push 到插件列表中。
那么我們就需要看 VueRouter 的 install 方法做了什么,VueRouter 類(lèi)定義在 src/index.js 文件中。
利用 vue 的插件機(jī)制,加載 vue-router
入口文件 index.js 對(duì)外 export 了一個(gè) VueRouter 類(lèi)。VueRouter 類(lèi)包含了 router 的各種方法,我們直接先來(lái)看一下 install 方法。
install 方法在 index.js 中綁定在 VueRouter 類(lèi)上:
import { install } from './install' VueRouter.install = install
它的實(shí)際實(shí)現(xiàn)是在 ./install.js 中,install 方法主要做了以下幾個(gè)事情:
1、設(shè)置了兩個(gè) mixin:beforeCreate 和 destroyed。
Vue.mixin({ beforeCreate () { if (isDef(this.$options.router)) { this._routerRoot = this this._router = this.$options.router this._router.init(this) Vue.util.defineReactive(this, '_route', this._router.history.current) } else { this._routerRoot = (this.$parent && this.$parent._routerRoot) || this } registerInstance(this, this) }, destroyed () { registerInstance(this) } })
2、在 Vue 上綁定 $route 和 $router。
Object.defineProperty(Vue.prototype, '$router', { get () { return this._routerRoot._router } }) Object.defineProperty(Vue.prototype, '$route', { get () { return this._routerRoot._route } })
3、注冊(cè)兩個(gè)組件,View 和 Link。
Vue.component('RouterView', View) Vue.component('RouterLink', Link)
4、設(shè)置 beforeRouteEnter、beforeRouteLeave 和 beforeRouteUpdate 的 merge 策略。merge 策略的介紹可以見(jiàn) 這里 ,簡(jiǎn)單來(lái)說(shuō)就是有重復(fù)的值時(shí)如何合并。
const strats = Vue.config.optionMergeStrategies // use the same hook merging strategy for route hooks strats.beforeRouteEnter = strats.beforeRouteLeave = strats.beforeRouteUpdate = strats.created
實(shí)例化 VueRouter
我們來(lái)看一下 VueRouter 的構(gòu)造函數(shù)。首先,constructor 會(huì)初始化一些屬性:
this.app = null this.apps = [] this.options = options this.beforeHooks = [] this.resolveHooks = [] this.afterHooks = [] this.matcher = createMatcher(options.routes || [], this)
其中 matcher 比較重要,后面會(huì)詳細(xì)說(shuō)。
之后會(huì)決定使用哪種模式:
let mode = options.mode || 'hash' this.fallback = mode === 'history' && !supportsPushState && options.fallback !== false if (this.fallback) { mode = 'hash' } if (!inBrowser) { mode = 'abstract' } this.mode = mode switch (mode) { case 'history': this.history = new HTML5History(this, options.base) break case 'hash': this.history = new HashHistory(this, options.base, this.fallback) break case 'abstract': this.history = new AbstractHistory(this, options.base) break default: if (process.env.NODE_ENV !== 'production') { assert(false, `invalid mode: ${mode}`) } }
由于 history 模式中的pushstate方法還有一些瀏覽器沒(méi)有支持。history 模式在瀏覽器不支持時(shí)會(huì)回退到hash模式。
之后根據(jù)不同模式選擇實(shí)例化不同模式的history類(lèi),可以看到 hash 模式和 history 模式分別對(duì)應(yīng)了 HashHistory 和 HTML5History 兩個(gè)類(lèi)。
此外,如果是服務(wù)器端渲染,需要進(jìn)行 router 匹配來(lái)獲取要渲染的頁(yè)面。此時(shí)服務(wù)器環(huán)境中沒(méi)有history api,因此要自行抽象實(shí)現(xiàn)一個(gè),就是 AbstractHistory。
實(shí)例化 Vue
實(shí)例化為Vue 類(lèi)時(shí),會(huì)將 VueRouter 的實(shí)例傳入,這個(gè)變量放在 this.$options.router
中。由于 vue router 時(shí)以插件形式引入的,因此 這個(gè) this.$options.router 還是給 vue router 自身來(lái)用的。
以上是“vue-router初始化的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。