亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

深入理解react-router 路由的實現原理

2024-05-06 16:46:12
字體:
來源:轉載
供稿:網友

React Router 是一個基于 React 之上的強大路由庫,它可以讓你向應用中快速地添加視圖和數據流,同時保持頁面與 URL 間的同步。本文從兩個方便來解析 react-router 實現原理。一:介紹 react-router 的依賴庫history;二:使用 history 庫,實現一個簡單的 react-router 路由。

history 介紹

history 是一個 JavaScript 庫,可讓您在 JavaScript 運行的任何地方輕松管理會話歷史記錄。history 抽象出各種環境中的差異,并提供最小的 API ,使您可以管理歷史堆棧,導航,確認導航以及在會話之間保持狀態。

history 有三種實現方式:

1、BrowserHistory:用于支持 HTML5 歷史記錄 API 的現代 Web 瀏覽器(請參閱跨瀏覽器兼容性) 
2、HashHistory:用于舊版Web瀏覽器
3、MemoryHistory:用作參考實現,也可用于非 DOM 環境,如 React Native 或測試

三種實現方法,都是創建了一個 history 對象,這里主要講下前面兩種:

const history = { length: globalHistory.length,  action: "POP",  location: initialLocation, createHref, push, // 改變location replace, go, goBack, goForward, block, listen //監聽路由變化};

1.頁面跳轉實現

BrowserHistory:pushState、replaceState;

HashHistory:location.hash、location.replace

function push(){ createKey(); // 創建location的key,用于唯一標示該location,是隨機生成的 if(BrowserHistory){ globalHistory.pushState({ key, state }, null, href); }else if(HashHistory){ window.location.hash = path; } //上報listener 更新state ...}function replace(){ createKey(); // 創建location的key,用于唯一標示該location,是隨機生成的 if(BrowserHistory){ globalHistory.replaceState({ key, state }, null, href);  }else if(HashHistory){ window.location.replace(window.location.href.slice(0, hashIndex >= 0 ? hashIndex : 0) + "#" path); }  //上報listener 更新state ... }

2.瀏覽器回退

BrowserHistory:popstate;

HashHistory:hashchang;

if(BrowserHistory){ window.addEventListener("popstate", routerChange);}else if(HashHistory){ window.addEventListener("hashchange", routerChange);}function routerChange(){ const location = getDOMLocation(); //獲取location //路由切換 transitionManager.confirmTransitionTo(location,callback=()=>{ //上報listener transitionManager.notifyListeners(); });}

通過 history 實現簡單 react-router

import { Component } from 'react';import createHistory from 'history/createHashHistory';const history = createHistory(); //創建 history 對象/** * 配置路由表 * @type {{"/": string}} */const router = { '/': 'page/home/index', '/my': 'page/my/index'}export default class Router extends Component { state = { page: null } async route(location) { let pathname = location.pathname; let pagePath = router[pathname]; // 加 ./的原因 https://webpack.docschina.org/api/module-methods#import- const Page = await import(`./${pagePath}`); //獲取路由對應的ui //設置ui this.setState({   Page: Page.default  }); } initListener(){ //監聽路由切換 history.listen((location, action) => {  //切換路由后,更新ui  this.route(location); }); } componentDidMount() { this.route(history.location); this.initListener(); } render() { const { Page } = this.state; return Page && <Page {...this.props} />; }}

目前react-router在項目中已有大量實踐,其優點可以總結如下:

風格: 與React融為一體,專為react量身打造,編碼風格與react保持一致,例如路由的配置可以通過component來實現

簡單: 不需要手工維護路由state,使代碼變得簡單

強大: 強大的路由管理機制,體現在如下方面

  • 路由配置: 可以通過組件、配置對象來進行路由的配置
  • 路由切換: 可以通過<Link> Redirect進行路由的切換
  • 路由加載: 可以同步記載,也可以異步加載,這樣就可以實現按需加載

使用方式: 不僅可以在瀏覽器端的使用,而且可以在服務器端的使用

當然react-router的缺點就是API不太穩定,在升級版本的時候需要進行代碼變動。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人综合网网址| 中文字幕国产精品久久| 日韩在线精品一区| 日韩免费高清在线观看| 欧美大片在线看免费观看| 欧美激情在线一区| 日韩欧美在线免费观看| 久久九九免费视频| 亚洲美女av电影| 精品少妇一区二区30p| 美女精品久久久| 国产午夜精品理论片a级探花| 成人激情视频在线播放| 日韩免费看的电影电视剧大全| 欧美福利小视频| 亚洲国语精品自产拍在线观看| 日韩美女在线观看| 中文字幕久久精品| 亚洲国产成人久久综合| 亚洲老头老太hd| 欧美高清视频在线| 亚洲日本aⅴ片在线观看香蕉| 97久久精品视频| 久久久97精品| 日韩在线视频观看正片免费网站| 久久色免费在线视频| 欧美黄色片视频| 亚洲性生活视频在线观看| 亚洲18私人小影院| 午夜精品蜜臀一区二区三区免费| 欧美大全免费观看电视剧大泉洋| 精品国产视频在线| 欧美激情在线播放| 精品日本高清在线播放| 亚洲精品大尺度| 国产综合在线视频| 国产精品h片在线播放| 国产九九精品视频| 亚洲美女av黄| 欧美丰满少妇xxxxx做受| 91av在线视频观看| 精品色蜜蜜精品视频在线观看| 亚洲免费影视第一页| 国产成人精品一区二区| 久久久久久一区二区三区| 亚洲三级av在线| 国产精品偷伦免费视频观看的| 91在线观看免费网站| 91视频88av| 国产精品久久久久久久美男| 日韩av免费观影| 亚洲国产成人在线播放| 久久成人在线视频| 欧美一区二区三区艳史| 国产精品mp4| 欧美一区二区大胆人体摄影专业网站| 欧美午夜丰满在线18影院| 日韩av片永久免费网站| 亚洲大胆人体视频| 日韩欧中文字幕| 精品香蕉一区二区三区| 91精品久久久久久综合乱菊| 日韩在线观看网址| 久久精品国产清自在天天线| 亚洲欧美日韩图片| 欧美亚洲伦理www| 一区二区成人av| 国产99久久精品一区二区| 久久99亚洲精品| 欧美日韩xxxxx| 日韩精品免费在线视频观看| 亚洲全黄一级网站| 亚洲最大的网站| 91a在线视频| 精品久久中文字幕| 精品国产区一区二区三区在线观看| 亚洲人免费视频| www.亚洲免费视频| 国产精品黄色影片导航在线观看| 欧美在线视频免费观看| 亚洲桃花岛网站| 性色av一区二区三区在线观看| 不卡在线观看电视剧完整版| 激情成人中文字幕| 国产亚洲精品久久久久久牛牛| 亚洲视频欧美视频| 成人深夜直播免费观看| 国产v综合v亚洲欧美久久| 精品久久久中文| 亚洲国内精品在线| 午夜精品视频网站| 亚洲a一级视频| 国产网站欧美日韩免费精品在线观看| 姬川优奈aav一区二区| 日韩在线观看免费全集电视剧网站| 91精品久久久久久久久久久久久| 黄色成人av网| 欧美精品制服第一页| 日韩在线观看电影| 亚洲尤物视频网| 欧美激情视频三区| 日韩精品在线观看网站| 久久男人的天堂| 国产欧美精品一区二区三区-老狼| 国产精品日韩欧美| 日韩大胆人体377p| 国产欧美欧洲在线观看| 久久躁狠狠躁夜夜爽| 福利二区91精品bt7086| 久久久亚洲欧洲日产国码aⅴ| 少妇高潮久久久久久潘金莲| 清纯唯美日韩制服另类| 国产精品爽黄69天堂a| 97国产精品视频人人做人人爱| 久久久久久久久国产精品| 国产69精品99久久久久久宅男| 亚洲人a成www在线影院| 欧美专区中文字幕| 日韩免费精品视频| 欧美国产亚洲精品久久久8v| 亚洲一区二区在线| 国产欧美亚洲精品| 5252色成人免费视频| 国产日韩欧美黄色| 久久国产精品电影| 亚洲福利视频专区| 美女视频黄免费的亚洲男人天堂| 欧美性猛交xxxx富婆弯腰| 国产成人午夜视频网址| 久久亚洲精品一区二区| 精品调教chinesegay| 91免费看视频.| 成人黄色片网站| 欧美精品一二区| 亲子乱一区二区三区电影| 中文字幕日韩精品有码视频| 久久91精品国产| 亚洲成人精品在线| 亚洲2020天天堂在线观看| 一区二区三区天堂av| 日韩暖暖在线视频| 亚洲一区二区久久久| 亚洲一区二区三区在线视频| 欧美午夜性色大片在线观看| 欧美裸体xxxxx| 日韩中文在线视频| 日韩欧美aaa| 中文字幕日韩综合av| 欧美日韩国产中文字幕| 91亚洲精品在线| 欧美巨乳美女视频| 亚洲丝袜一区在线| 亚洲欧洲日韩国产| 欧美精品videosex极品1| 久久精品99无色码中文字幕| 亚洲国产精久久久久久| 日韩一区二区三区在线播放| 成人激情视频在线播放| 欧美性受xxx| 久久精品中文字幕免费mv| xvideos成人免费中文版| 亚洲精品网址在线观看| 91在线观看免费| 欧美性猛交xxxx免费看漫画|