电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

詳解vue的hash跳轉原理

瀏覽:9日期: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
相關文章:
主站蜘蛛池模板: 机床主轴维修|刀塔维修|C轴维修-常州翔高精密机械有限公司 | 密封无忧网 _ 专业的密封产品行业信息网 | 冷库安装厂家_杭州冷库_保鲜库建设-浙江克冷制冷设备有限公司 | 丽陂特官网_手机信号屏蔽器_Wifi信号干扰器厂家_学校考场工厂会议室屏蔽仪 | 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | 济南律师,济南法律咨询,山东法律顾问-山东沃德律师事务所 | 天津次氯酸钠酸钙溶液-天津氢氧化钠厂家-天津市辅仁化工有限公司 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | 304不锈钢无缝管_不锈钢管厂家 - 隆达钢业集团有限公司 | 自动钻孔机-全自动数控钻孔机生产厂家-多米(广东)智能装备有限公司 | 广州展览制作|展台制作工厂|展览设计制作|展览展示制作|搭建制作公司 | 致胜管家软件服务【在线免费体验】 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | 模具硅橡胶,人体硅胶,移印硅胶浆厂家-宏图硅胶科技 | 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 北京公寓出租网-北京酒店式公寓出租平台| 上海乾拓贸易有限公司-日本SMC电磁阀_德国FESTO电磁阀_德国FESTO气缸 | 沈阳庭院景观设计_私家花园_别墅庭院设计_阳台楼顶花园设计施工公司-【沈阳现代时园艺景观工程有限公司】 | 广州各区危化证办理_危险化学品经营许可证代办 | 网带通过式抛丸机,,网带式打砂机,吊钩式,抛丸机,中山抛丸机生产厂家,江门抛丸机,佛山吊钩式,东莞抛丸机,中山市泰达自动化设备有限公司 | 400电话_400电话申请_888元包年_400电话办理服务中心_400VIP网 | 福州甲醛检测-福建室内空气检测_环境检测_水质检测-福建中凯检测技术有限公司 | 骨密度仪-骨密度测定仪-超声骨密度仪-骨龄测定仪-天津开发区圣鸿医疗器械有限公司 | 中宏网-今日新闻-财经新闻| 化工ERP软件_化工新材料ERP系统_化工新材料MES软件_MES系统-广东顺景软件科技有限公司 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | 常州律师事务所_常州律所_常州律师-江苏乐天律师事务所 | 深圳诚暄fpc首页-柔性线路板,fpc柔性线路板打样生产厂家 | lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 玉米深加工设备|玉米加工机械|玉米加工设备|玉米深加工机械-河南成立粮油机械有限公司 | 交变/复合盐雾试验箱-高低温冲击试验箱_安奈设备产品供应杭州/江苏南京/安徽马鞍山合肥等全国各地 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | hc22_hc22价格_hc22哈氏合金—东锜特殊钢| 818手游网_提供当下热门APP手游_最新手机游戏下载 | 档案密集架_电动密集架_移动密集架_辽宁档案密集架-盛隆柜业厂家现货批发销售价格公道 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 骨密度检测仪_骨密度分析仪_骨密度仪_动脉硬化检测仪专业生产厂家【品源医疗】 |