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

詳解前端路由實(shí)現(xiàn)與react-router使用姿勢

 更新時(shí)間:2017年08月07日 09:52:14   作者:Gavin13140  
本篇文章主要介紹了詳解前端路由和react-router使用姿勢,詳細(xì)的介紹了react-router的用法,有興趣的可以了解一下

路由

對于有過SPA開發(fā)經(jīng)驗(yàn)的人來說,路由這個(gè)名詞并不陌生,前端的路由和后端的路由在實(shí)現(xiàn)技術(shù)上不一樣,但是原理都是一樣的。在 HTML5 的 history API 出現(xiàn)之前,前端的路由都是通過 hash 來實(shí)現(xiàn)的,hash 能兼容低版本的瀏覽器。它的 URI 規(guī)則中需要帶上 #。Web 服務(wù)并不會解析 hash,也就是說 # 后的內(nèi)容 Web 服務(wù)都會自動忽略,但是 JavaScript 是可以通過 window.location.hash 讀取到的,讀取到路徑加以解析之后就可以響應(yīng)不同路徑的邏輯處理。

簡單介紹AngularJs UI-Router路由

如果你有過AngularJS開發(fā)經(jīng)驗(yàn),#并不陌生,angularjs有自己官方實(shí)現(xiàn)的路由體系,也有比較具有代表性的第三方嵌套路由機(jī)制UI-Router; 如下代碼塊所示:

.state("main.list",angularAMD.route({
    url : '/list/:params',//url &參數(shù)
    views : {
      "header@main" : angularAMD.route({
        templateUrl : 'simple/view/main/html/main/Header.html',
        controller:'HeadController',
        controllerUrl:[ ****.js
                  ]
      }),
      "menu@main" : angularAMD.route({
        templateUrl : 'simple/view/main/html/main/MenuModule.html',
        controller : "MenuController",
        controllerUrl:[ ****.js]
      }),
      "mainContent@main":angularAMD.route({
        templateUrl : 'simple/view/main/html/main/MainContent.html'
      })
    }
  }))

state()函數(shù)的第一個(gè)參數(shù)就是路由,“main.list” 是一個(gè)嵌套路由機(jī)制,當(dāng)頁面跳轉(zhuǎn)到 “main.list”路由下時(shí)會先加載 state(“main”,*)下的模塊及其資源(html,js等),隨后加載state(”main.list”)下的模塊和資源(html,js等),實(shí)現(xiàn)路由嵌套;

react-router

-先上一段代碼

<Router history={ hashHistory }>
  <Route path='/' component={CoreLayout}>
  <IndexRoute component={HomeView}/>
  <Route path=”/HODE_ROUTE/:param“ component={HomeView}/>
  <Route path=“ /AUDIT_ROUTE/:param" component={AuditView}/>
  <Route path=“/CHART_ROUTE” component={ChartView}/>
  </Route>
</Router>

React-router以jsx語法類似于DOM結(jié)構(gòu)的形式實(shí)現(xiàn)router嵌套;與AngularJs 的UI-Router看似差別很大,實(shí)則思想雷同;

Angular的實(shí)現(xiàn)邏輯:

跳轉(zhuǎn)=》state=》module=》靜態(tài)資源(js,css,html)=》show(頁面展示)

react-router的實(shí)現(xiàn)邏輯:

跳轉(zhuǎn)=》path=》component=》靜態(tài)資源(js,css,html)=》show(頁面展示)
本文主要講react-router,下面簡單介紹react-router的使用姿勢:

react-router常用組件入門

嵌套路由

<Router history={hashHistory}>
 <Route path="/" component={App}>
  <Route path="/repos" component={Repos}/>
  <Route path="/about" component={About}/>
 </Route>
</Router>

上面代碼中,用戶訪問/repos時(shí),會先加載App組件,然后在它的內(nèi)部再加載Repos組件。

<App>
 <Repos/>
</App>

子路由也可以不寫在Router組件里面,單獨(dú)傳入Router組件的routes屬性

let routes = <Route path="/" component={App}>
 <Route path="/repos" component={Repos}/>
 <Route path="/about" component={About}/>
</Route>;

<Router routes={routes} history={browserHistory}/>

path 屬性

Route組件的path屬性指定路由的匹配規(guī)則,看下面例子

<Route path="inbox" component={Inbox}>
  <Route path="messages/:id" component={Message} />
</Route>

上面代碼中,當(dāng)用戶訪問/inbox/messages/:id時(shí),會加載下面的組件。

<Inbox>
 <Message/>
</Inbox>

IndexRoute 組件

類似index.html ,默認(rèn)加載組件,下面代碼默認(rèn)加載home組件

<Router>
 <Route path="/" component={App}>
  <IndexRoute component={Home}/>
  <Route path="accounts" component={Accounts}/>
  <Route path="statements" component={Statements}/>
 </Route>
</Router>

現(xiàn)在,用戶訪問/的時(shí)候,加載的組件結(jié)構(gòu)如下。

<App>
 <Home/>
</App>

Redirect 組件

Redirect組件用于路由的跳轉(zhuǎn),即用戶訪問一個(gè)路由,會自動跳轉(zhuǎn)到另一個(gè)路由。

<Route path="inbox" component={Inbox}>
 {/* 從 /inbox/messages/:id 跳轉(zhuǎn)到 /messages/:id */}
 <Redirect from="messages/:id" to="/messages/:id" />
</Route>

現(xiàn)在訪問/inbox/messages/5,會自動跳轉(zhuǎn)到/messages/5。

Link

Link組件用于取代a標(biāo)簽,生成一個(gè)鏈接,允許用戶點(diǎn)擊后跳轉(zhuǎn)到另一個(gè)路由。它基本上就是a標(biāo)簽的React 版本,可以接收Router的狀態(tài)。

表單處理

Link組件用于正常的用戶點(diǎn)擊跳轉(zhuǎn),但是有時(shí)還需要表單跳轉(zhuǎn)、點(diǎn)擊按鈕跳轉(zhuǎn)等操作。這些情況怎么跟React Router對接呢?

第一種方法是使用browserHistory.push

 handleSubmit(event) {
  event.preventDefault()
  const userName = event.target.elements[0].value
  const repo = event.target.elements[1].value
  const path = `/repos/${userName}/${repo}`
  browserHistory.push(path)
 }

${userName} 一種后端語言常用的表達(dá)式寫法,可在字符串中取變量

 handleSubmit(event) {
  // ...
  this.context.router.push(path)
 },

第二種方法是使用context對象。

export default React.createClass({

 // ask for `router` from context
 contextTypes: {
  router: React.PropTypes.object
 },

 handleSubmit(event) {
  // ...
  this.context.router.push(path)
 },
})

多人協(xié)作開發(fā)router文件管理

一般一個(gè)項(xiàng)目都會有一個(gè)統(tǒng)一的router文件,相當(dāng)于一個(gè)router池,不同的請求,請求router池中所匹配的路徑,加載請求所需頁面。 but 。。。 每個(gè)開發(fā)者開發(fā)一個(gè)組件都會需要配置路由,會導(dǎo)致router文件不易管理,容易導(dǎo)致沖突,甚至故障。 so。。,也許,可能可以每個(gè)組件文件夾下對于一個(gè)XXX.router 文件,前端代碼打包上傳到線上時(shí)觸發(fā)某個(gè)鉤子函數(shù),將XXX.router文件統(tǒng)一合并到中央router文件中,從而避免多人操作router文件。

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

相關(guān)文章

  • React?Hook?四種組件優(yōu)化總結(jié)

    React?Hook?四種組件優(yōu)化總結(jié)

    這篇文章主要介紹了React?Hook四種組件優(yōu)化總結(jié),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)孩子,需要的朋友可以參考一下
    2022-07-07
  • React?Virtual?DOM前端框架全面分析

    React?Virtual?DOM前端框架全面分析

    這篇文章主要為大家介紹了React?Virtual?DOM前端框架全面分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • React前端開發(fā)createElement源碼解讀

    React前端開發(fā)createElement源碼解讀

    這篇文章主要為大家介紹了React前端開發(fā)createElement源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • React組件傳參方式你了解嗎

    React組件傳參方式你了解嗎

    眾所周知?,在業(yè)務(wù)開發(fā)中,無論用的什么框架,首先要熟悉項(xiàng)目搭建,路由配置和組件通信,所以我們今天要探究的就是React中組件通信的幾種方式,快跟隨小編一起學(xué)習(xí)起來吧
    2024-03-03
  • 使用 Rails API 構(gòu)建一個(gè) React 應(yīng)用程序的詳細(xì)步驟

    使用 Rails API 構(gòu)建一個(gè) React 應(yīng)用程序的詳細(xì)步驟

    這篇文章主要介紹了使用 Rails API 構(gòu)建一個(gè) React 應(yīng)用程序的詳細(xì)步驟,主要包括后端:Rails API部分,前端:React部分及React組件的相關(guān)操作,具有內(nèi)容詳情跟隨小編一起看看吧
    2021-08-08
  • VSCode 配置React Native開發(fā)環(huán)境的方法

    VSCode 配置React Native開發(fā)環(huán)境的方法

    本篇文章主要介紹了VSCode 配置React Native開發(fā)環(huán)境的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • react中關(guān)于函數(shù)調(diào)用()與bind this的原因及分析

    react中關(guān)于函數(shù)調(diào)用()與bind this的原因及分析

    這篇文章主要介紹了react中關(guān)于函數(shù)調(diào)用()與bind this的原因及分析,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 解決react組件渲染兩次的問題

    解決react組件渲染兩次的問題

    這篇文章主要介紹了解決react組件渲染兩次的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 實(shí)例講解React 組件生命周期

    實(shí)例講解React 組件生命周期

    這篇文章主要介紹了React 組件生命周期的相關(guān)資料,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • webpack4 + react 搭建多頁面應(yīng)用示例

    webpack4 + react 搭建多頁面應(yīng)用示例

    這篇文章主要介紹了webpack4 + react 搭建多頁面應(yīng)用示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08

最新評論