日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解vue的hash跳轉原理

瀏覽:29日期:2022-10-02 17:06:39

在new vueRouter的時候我們可以傳入一個mode屬性,他可以接收三個值:hash/history/abstract

詳解vue的hash跳轉原理

hash和history的區別

history的路徑更美觀一點 比如http://yoursite.com/user/id,history是基于pushState()來完成 URL 跳轉而無須重新加載頁面。 但是強制刷新還是會有問題(服務端來解決這個問題),所以history模式需要后端人員配合使用。

hash的路徑會帶有#,比如http://yoursite.com#/user/id

HashHistory

class VueRouter{ constructor(options){ this.matcher = createMatcher(options.routes || []);//這里為了講解hash模式 所以就不進行判斷用戶傳進來的是哪種模式了 this.history = new HashHistory(this);//this vue-router的實例 }}

源碼這里創建了一個基類我們這里和源碼統一,這個基類封裝了三種模式公用的方法和屬性,那么我們在這里創建一個HashHistory和基類History

import History from ’./base’// hash路由export default class HashHistory extends History{ constructor(router){ super(router); //繼承調用父類 等于call }}// 路由的基類export default class History { constructor(router){ this.router = router; }}

如果是hash路由,打開網站如果沒有hash默認應該添加#/

import History from ’./base’;function ensureSlash(){ if(window.location.hash){ return } window.location.hash = ’/’}export default class HashHistory extends History{ constructor(router){ super(router); ensureSlash(); // 確保有hash }}

再看一下初始化的邏輯(上面的router.init函數)

init(app){ const history = this.history; // 初始化時,應該先拿到當前路徑,進行匹配邏輯 // 讓路由系統過度到某個路徑 const setupHashListener = ()=> { history.setupListener(); // 監聽路徑變化 } history.transitionTo( // 父類提供方法負責跳轉 history.getCurrentLocation(), // 子類獲取對應的路徑 // 跳轉成功后注冊路徑監聽,為視圖更新做準備 setupHashListener )}

這里我們要分別實現 transitionTo(基類方法)、 getCurrentLocation 、setupListener

getCurrentLocation實現

function getHash(){ return window.location.hash.slice(1);}export default class HashHistory extends History{ // ... getCurrentLocation(){ return getHash(); }}setupListener實現

export default class HashHistory extends History{ // ... setupListener(){ window.addEventListener(’hashchange’, ()=> { // 根據當前hash值 過度到對應路徑 this.transitionTo(getHash()); }) }}TransitionTo實現

export function createRoute(record, location) { // {path:’/’,matched:[record,record]} let res = []; if (record) { // 如果有記錄 while(record){ res.unshift(record); // 就將當前記錄的父親放到前面 record = record.parent } } return { ...location, matched: res }}export default class History { constructor(router) { this.router = router; // 根據記錄和路徑返回對象,稍后會用于router-view的匹配 this.current = createRoute(null, { path: ’/’ }) } // 核心邏輯 transitionTo(location, onComplete) { // 去匹配路徑 let route = this.router.match(location); // 相同路徑不必過渡 if( location === route.path && route.matched.length === this.current.matched.length){ return } //更新路由并且下面會提到改變根實例上的_route屬性 this.updateRoute(route) onComplete && onComplete(); }}

export default class VueRouter{ // ... //做一個代理 match(location){ return this.matcher.match(location); }}macth方法

function match(location){ // 稍后根據路徑找到對應的記錄 let record = pathMap[location] if (record) { // 根據記錄創建對應的路由 //參數:/about/a:{path:xx,component...},path:’/about/a’ return createRoute(record,{ path:location }) } // 找不到則返回空匹配 return createRoute(null, { path: location })}

我們不難發現路徑變化時都會更改current屬性,我們可以把current屬性變成響應式的,每次current變化刷新視圖即可在install方法中

install(Vue) { Vue.mixin({ // 給所有組件的生命周期都增加beforeCreate方法 beforeCreate() { if (this.$options.router) { //調用Vue類中雙向數據綁定方法 Vue.util.defineReactive(this,’_route’,this._router.history.current); } } }); // $route和$router方法 這兩個方法僅僅是vue中最常見的代理 僅僅是為了更加方便 Object.defineProperty(Vue.prototype,’$route’,{ // 每個實例都可以獲取到$route屬性 get(){ return this._routerRoot._route;//上面剛進行雙向數據綁定的 } }); Object.defineProperty(Vue.prototype,’$router’,{ // 每個實例都可以獲取router實例 get(){ return this._routerRoot._router; } }) }

切換路由每次初始化時都需要調用更新_route的方法,因為install的時候把_route進行雙向數據綁定,剛進來是沒有this._router.history.current的,通過發布訂閱方式來進行訂閱和更新操作;在init方法中增加監聽函數

history.listen((route) => { // 需要更新_route屬性,出入一個函數 app._route = route});

export default class History { constructor(router) { // ... this.cb = null; } listen(cb){ this.cb = cb; // 注冊函數 } updateRoute(route){ this.current =route; this.cb && this.cb(route); // 更新current后 更新_route屬性 }}

以上就是詳解vue的hash跳轉原理的詳細內容,更多關于vue的hash跳轉原理的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品99一区二区| 在线日韩av| av不卡在线看| 欧美va天堂在线| 日本美女一区| 四虎成人av| 麻豆理论在线观看| 丰满少妇一区| 精品成av人一区二区三区| 麻豆久久久久久| 精品国产亚洲一区二区三区在线| 日韩精品久久理论片| 99久久99久久精品国产片果冰| 麻豆一区二区99久久久久| 国产精品成人国产| 欧美激情91| 成人影视亚洲图片在线| 另类专区亚洲| 免费视频亚洲| 免费在线看一区| 91免费精品国偷自产在线在线| 91亚洲精品视频在线观看 | 亚洲人成毛片在线播放女女| 免费一级片91| 国产欧美一级| 麻豆免费精品视频| 亚洲高清二区| 国产欧美日韩精品一区二区免费| 精品在线网站观看| 欧洲毛片在线视频免费观看| 亚洲人成高清| 午夜av成人| 日韩精品视频一区二区三区| 国产精品精品国产一区二区| 欧美日韩四区| 国产一区二区三区视频在线| 午夜久久美女| 精品三区视频| 久久大逼视频| 欧美13videosex性极品| 亚洲精品三级| 免费在线亚洲欧美| 亚洲视频国产精品| 欧洲亚洲一区二区三区| 日韩二区在线观看| 亚洲免费激情| 神马日本精品| 久久精品毛片| 7777精品| 日本va欧美va瓶| 亚洲免费网址| 欧美日韩中文一区二区| 久久只有精品| 国产欧美日韩一区二区三区在线| 免费看的黄色欧美网站| 久久精品国产68国产精品亚洲| 日韩精品视频中文字幕| 天堂av在线一区| 国产精品腿扒开做爽爽爽挤奶网站| 香蕉成人av| 日韩欧美三级| 国产精品毛片一区二区在线看| 国产精品99久久免费观看| 最新国产精品| 亚洲精品看片| 久久国产免费看| 中文无码日韩欧| 久久亚洲国产精品一区二区| 午夜精品一区二区三区国产| 岛国av在线网站| 久久久91麻豆精品国产一区| 亚洲深夜福利在线观看| 蜜桃一区二区三区在线观看| 六月丁香综合| 欧美一区91| 国产一区2区在线观看| 黄在线观看免费网站ktv| 日韩中文视频| 夜久久久久久| 日本亚州欧洲精品不卡| 久久精品99国产精品日本| 国产精品亚洲综合久久| 精品色999| 欧美精选一区二区三区| 欧美专区一区二区三区| 日韩一区二区三区四区五区| 免费在线看一区| 国产精品v一区二区三区| 91欧美在线| 三级亚洲高清视频| 欧美激情91| 国户精品久久久久久久久久久不卡| 国产精品毛片| 九九99久久精品在免费线bt| 久久三级福利| 91av一区| 亚洲精品一二三区区别| 国产精品视频首页| 欧美日韩国产传媒| 牛牛精品成人免费视频| 中文久久精品| 日本精品另类| 亚洲一级二级| 精品一区二区三区中文字幕在线| 国产一区观看| 久久免费影院| 蜜臀va亚洲va欧美va天堂| 国产一区日韩| 日韩精品免费视频人成| 亚洲激情中文在线| 福利一区二区免费视频| 日韩手机在线| 国产精品日韩欧美一区| 日韩三区免费| 国产不卡人人| 国产一区二区三区四区| 日韩av不卡一区二区| 亚洲久久视频| 蜜桃91丨九色丨蝌蚪91桃色| 日韩亚洲国产欧美| 美女网站一区| 精品一区在线| 激情五月综合网| 欧美在线影院| 激情婷婷久久| 天堂av在线| 中国字幕a在线看韩国电影| 日本不卡一二三区黄网| 日韩国产在线一| 蜜臀av在线播放一区二区三区| 久久久久网站| 三上悠亚国产精品一区二区三区| 日韩av成人高清| 中国女人久久久| 欧美~级网站不卡| av日韩中文| 日韩成人精品一区| 久久香蕉精品香蕉| 国产精品99久久久久久董美香| 久久中文字幕av| 精品捆绑调教一区二区三区| 精品国产一区二| 久久91视频| 久久影院资源站| 91精品麻豆| 国产精品成人3p一区二区三区| 亚洲综合婷婷| 亚洲免费网址| 蜜臀国产一区二区三区在线播放 | 日欧美一区二区| 蜜桃视频一区二区三区在线观看| 蜜臀91精品一区二区三区| 亚洲欧美久久久| 亚洲男女自偷自拍| 免费成人在线观看| 亚洲三级av| 国产女人18毛片水真多18精品| 国产三级精品三级在线观看国产| 免费成人在线影院| 婷婷精品在线观看| 9国产精品视频| 五月亚洲婷婷 | 亚洲精品影视| 日韩超碰人人爽人人做人人添| 欧美精品一区二区久久| 黄色日韩在线| 亚洲女同中文字幕| 综合亚洲色图| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 天堂va欧美ⅴa亚洲va一国产| 西西人体一区二区| 亚洲综合专区| 热久久国产精品| 欧美日韩精品一区二区三区在线观看| 国产美女撒尿一区二区| 久久精品国产999大香线蕉 | 中文字幕亚洲在线观看| 国产精品久一| 国产精品久久久久久av公交车 | 六月丁香综合| 国产精品流白浆在线观看| 欧美激情久久久久久久久久久| 麻豆视频在线观看免费网站黄 | 精品视频91| 欧美中文日韩| 国产美女高潮在线| 亚洲精一区二区三区| 亚洲播播91| 日韩精品免费一区二区在线观看| 亚洲精品少妇| 狠狠久久婷婷| 国产欧美日韩视频在线| 午夜欧美精品久久久久久久| 国产一区二区亚洲| 蜜桃传媒麻豆第一区在线观看| 国产精品大片免费观看| 最新国产精品久久久| 黄色成人精品网站| 亚洲成av在线| 高清日韩中文字幕|