国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

vue-router 源碼之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 vue-router

2024-05-06 15:32:59
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

通過(guò)上篇,我們知道前端理由的兩種實(shí)現(xiàn)方法,Hash 路由與 History 路由,并且用它們分別實(shí)現(xiàn)了一個(gè)前端路由。

接下來(lái)我們就將 Vue 與 Hash 路由結(jié)合,實(shí)現(xiàn)一個(gè)非常簡(jiǎn)單的 vue-router 吧。

開(kāi)始實(shí)現(xiàn)

想象一下,如果自己實(shí)現(xiàn)了一個(gè) vue-router,會(huì)怎么去使用呢?參考 vue-router 官方的使用方式,看看 html 的使用:

<div id="app"> <p>  <router-link to="#/">home</router-link>  <router-link to="#/book">book</router-link>  <router-link to="#/movie">movie</router-link> </p> <router-view></router-view></div>

這里會(huì)有 router-link 和 router-view 兩個(gè)組件需要我們來(lái)實(shí)現(xiàn)。再來(lái)看 js 的:

const Home = { template: '<div>home</div>' };const Book = { template: '<div>book</div>' };const Movie = { template: '<div>movie</div>' };const routes = [ { path: '/', component: Home }, { path: '/book', component: Book }, { path: '/movie', component: Movie }];const router = new VueRouter(Vue, { routes});new Vue({ el: '#app'});

這里會(huì)有我們自己定義的組件 Home、Book 和 Movie,并且有它們各自對(duì)應(yīng)的路由。我們實(shí)現(xiàn)的 VueRouter 跟官方的有些區(qū)別,在 VueRouter 被 new 時(shí)是將 Vue 作為參數(shù)傳入,而不是注入掛載到根實(shí)例下。

接下來(lái)就是 VueRouter 的實(shí)現(xiàn)了。

VueRouter

要怎么來(lái)實(shí)現(xiàn) VueRouter 呢,先提供一下實(shí)現(xiàn)的思路:

    綁定 hashchange 事件,實(shí)現(xiàn)前端路由; 將傳入的路由和組件做一個(gè)路由映射,切換哪個(gè)路由即可找到對(duì)應(yīng)的組件顯示; 需要 new 一個(gè) Vue 實(shí)例還做響應(yīng)式通信,當(dāng)路由改變的時(shí)候,router-view 會(huì)響應(yīng)更新; 注冊(cè) router-link 和 router-view 組件。

先創(chuàng)建一個(gè) VueRouter:

class VueRouter { constructor (Vue, options) {  this.$options = options; }}

綁定事件

給 VueRouter 添加一個(gè)綁定事件的方法,一旦路由發(fā)生改變,會(huì)觸發(fā) onHashChange 方法。

constructor (Vue, options) { this.init();}// 綁定事件init () { window.addEventListener('load', this.onHashChange.bind(this), false); window.addEventListener('hashchange', this.onHashChange.bind(this), false);}

路由映射表

將傳入的 options 設(shè)置成一張路由映射表,以便于通過(guò)路由查找到對(duì)應(yīng)的組件。

constructor (Vue, options) { this.$options = options; this.routeMap = {}; this.createRouteMap(this.$options);}// 路由映射表createRouteMap (options) { options.routes.forEach(item => {  this.routeMap[item.path] = item.component; });}

options 之中,路由與組件的關(guān)系:

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 马尔康县| 宜都市| 旬邑县| 南康市| 嘉义县| 江阴市| 延吉市| 荔波县| 通山县| 冕宁县| 元氏县| 慈利县| 社会| 黄冈市| 丰原市| 盘山县| 汤原县| 贺州市| 皮山县| 行唐县| 蚌埠市| 固始县| 黄浦区| 宝清县| 太谷县| 岑巩县| 当阳市| 黎城县| 新津县| 如东县| 石泉县| 兰考县| 鲁山县| 曲水县| 宾阳县| 资阳市| 安阳市| 松桃| 谢通门县| 咸阳市| 屏南县|