欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue-router 初始化時(shí)做了什么

 更新時(shí)間:2018年06月11日 08:33:40   作者:梅旭光的個(gè)人博客  
這篇文章主要介紹了詳解vue-router 初始化時(shí)做了什么,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

最近因?yàn)闃I(yè)務(wù)需要,實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的前端 router,正好也來(lái)看一下 vue router 是怎么實(shí)現(xiàn)的。這次先來(lái)一起看看 vue-router 初始化時(shí)做了什么。

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 初始化所做的事情就是這些,下篇博客我們來(lái)一起看一下 vue router 實(shí)際運(yùn)行時(shí)發(fā)生了什么。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue實(shí)現(xiàn)瀏覽器端掃碼功能

    Vue實(shí)現(xiàn)瀏覽器端掃碼功能

    本文主要介紹,通過(guò)使用基于 vue技術(shù)棧的前端開(kāi)發(fā)技術(shù),在瀏覽器端調(diào)起攝像頭,并進(jìn)行掃碼識(shí)別功能,對(duì)識(shí)別到的二維碼進(jìn)行跳轉(zhuǎn)或其他操作處理,對(duì)vue瀏覽器掃碼功能的實(shí)現(xiàn)代碼感興趣的朋友一起看看吧
    2021-10-10
  • vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件

    vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件

    這篇文章主要介紹了vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • vue-froala-wysiwyg 富文本編輯器功能

    vue-froala-wysiwyg 富文本編輯器功能

    這篇文章主要介紹了vue-froala-wysiwyg 富文本編輯器功能,分步驟給大家介紹了vue3.中如何安裝使用froala,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 淺析從面向?qū)ο笏季S理解Vue組件

    淺析從面向?qū)ο笏季S理解Vue組件

    用面向?qū)ο蟮乃季S去理解Vue組件,可以將所有的事物都抽象為對(duì)象,而類(lèi)或者說(shuō)是組件,都具有屬性和操作。這篇文章主要介紹了嘗試用面向?qū)ο笏季S理解Vue組件,需要的朋友可以參考下
    2021-07-07
  • vue 使用鼠標(biāo)滾動(dòng)加載數(shù)據(jù)的例子

    vue 使用鼠標(biāo)滾動(dòng)加載數(shù)據(jù)的例子

    今天小編就為大家分享一篇vue 使用鼠標(biāo)滾動(dòng)加載數(shù)據(jù)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • el-table表頭全選框隱藏或禁用設(shè)置方法

    el-table表頭全選框隱藏或禁用設(shè)置方法

    有時(shí)候我們使用el-table的選擇框時(shí),如果涉及修改、刪除時(shí),可能一次只允許用戶(hù)選擇一條,這樣的話(huà)如果使用頂部的全選復(fù)選框就不合適了,這篇文章主要給大家介紹了關(guān)于el-table表頭全選框隱藏或禁用設(shè)置的相關(guān)資料,需要的朋友可以參考下
    2023-09-09
  • element中一個(gè)單選框radio時(shí)的選中和取消代碼詳解

    element中一個(gè)單選框radio時(shí)的選中和取消代碼詳解

    這篇文章主要給大家介紹了關(guān)于element中一個(gè)單選框radio時(shí)的選中和取消的相關(guān)資料,文中通過(guò)圖文以及代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-09-09
  • Vue使用Proxy代理后仍無(wú)法生效的解決

    Vue使用Proxy代理后仍無(wú)法生效的解決

    這篇文章主要介紹了Vue使用Proxy代理后仍無(wú)法生效的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • ElementUI實(shí)現(xiàn)在下拉列表里面進(jìn)行搜索功能詳解

    ElementUI實(shí)現(xiàn)在下拉列表里面進(jìn)行搜索功能詳解

    有時(shí)候需要用到下拉列表全選和搜索,下面這篇文章主要給大家介紹了關(guān)于ElementUI實(shí)現(xiàn)在下拉列表里面進(jìn)行搜索功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • 解決vue-cli?卸載不掉的問(wèn)題

    解決vue-cli?卸載不掉的問(wèn)題

    這篇文章主要介紹了vue-cli?卸載不掉的問(wèn)題解決方法,文中給大家介紹了安裝后問(wèn)題分析及解決方案,需要的朋友可以參考下
    2023-01-01

最新評(píng)論