亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

react-router browserHistory刷新頁面404問題解決方法

 更新時間:2017年12月29日 09:58:42   作者:熊建剛  
本篇文章主要介紹了react-router browserHistory刷新頁面404問題解決方法,非常具有實用價值,需要的朋友可以參考下

使用React開發(fā)新項目時,遇見了刷新頁面,直接訪問二級或三級路由時,訪問失敗,出現(xiàn)404或資源加載異常的情況,本篇針對此問題進行分析并總結(jié)解決方案。

背景

使用webpack-dev-server做本地開發(fā)服務(wù)器時,正常情況只需要簡單使用webpack-dev-server指令啟動即可,但是當(dāng)項目處于以下兩種情況時,往往需要有嵌套路由和異步加載路由:

  1. 我們使用react-router這種路由庫構(gòu)建單頁面應(yīng)用路由;
  2. 使用html-webpack-plugin插件動態(tài)將加載js的<script>標(biāo)簽注入html文檔;

這時,訪問localhost:9090是可以正常加載頁面和js等文件的,但是當(dāng)我們需要訪問二級甚至三級路由或者刷新頁面時,如localhost:9090/posts/92時,可能會出現(xiàn)兩種情況:

  1. 頁面加載失敗,返回Cannot Get(404);
  2. 服務(wù)響應(yīng),但是沒有返回webpack處理輸出的html文件,導(dǎo)致無法加載js資源,第二種情況如圖:

那么我們怎么處理才能正常訪問,各頁面路由呢?博主追蹤溯源,查找文檔配置后解決了問題,本篇就是對整個解決問題過程的總結(jié)。

分析問題

發(fā)現(xiàn)問題后,我們就要開始分析,解決問題了,我們判斷這個問題一般是兩方面原因造成:

  1. react-router路前端由配置;
  2. webpack-dev-server服務(wù)配置;

react-router

因為前端路由更容易確定問題,更方便分析,而且對于react-router更熟悉,所以首先去查詢react-router路由庫相關(guān)配置信息,發(fā)現(xiàn)文檔中提到了使用browserHistory時,會創(chuàng)建真實的URL,處理初始/請求沒有問題,但是對于跳轉(zhuǎn)路由后,刷新頁面或者直接訪問該URL時,會發(fā)現(xiàn)無法正確相應(yīng),更多信息查看參考文檔,文檔中也提供了幾種服務(wù)器配置解決方式:

Node

const express = require('express')
const path = require('path')
const port = process.env.PORT || 8080
const app = express()

// 通常用于加載靜態(tài)資源
app.use(express.static(__dirname + '/public'))

// 在你應(yīng)用 JavaScript 文件中包含了一個 script 標(biāo)簽
// 的 index.html 中處理任何一個 route
app.get('*', function (request, response){
 response.sendFile(path.resolve(__dirname, 'public', 'index.html'))
})

app.listen(port)
console.log("server started on port " + port)

在使用Node作為服務(wù)時,需要使用通配符*監(jiān)聽所有請求,返回目標(biāo)html文檔(引用js資源的html)。

Nginx

如果使用的是nginx服務(wù)器,則只需要使用try_files 指令:

server {
 ...
 location / {
  try_files $uri /index.html
 }
}

Apache

如果使用Apache服務(wù)器,則需要在項目根目錄創(chuàng)建.htaccess文件,文件包含如下內(nèi)容:

RewriteBase /
RewriteRule ^index\.html$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.html [L]

以下都是針對服務(wù)器的配置,可惜的是我們目前還沒引入相關(guān)服務(wù)器,只是使用了webpack-dev-server的內(nèi)置服務(wù),但是我們已經(jīng)找到問題所在了,就是路由請求無法匹配返回html文檔,所以接下來就該去webpack-dev-server文檔中查找解決方式了。

webpack-dev-server

在這里不得不吐槽一下webpack-dev-server官方文檔,博主反復(fù)看了幾遍,才看清楚了問題所在,這里也分兩種情況:

  1. 沒有修改output.publicPath,即webpack配置文件中沒有聲明值,屬于默認(rèn)情況;
  2. 設(shè)置了output.publicPath為自定義值;

點此查看文檔

默認(rèn)情況

默認(rèn)情況下,沒有修改output.publicPath值,只需要設(shè)置webpack-dev-server的historyApiFallback配置:

devServer: {
 historyApiFallback: true
}

If you are using the HTML5 history API you probably need to serve your index.html in place of 404 responses, which can be done by setting historyApiFallback: true

如果你的應(yīng)用使用HTML5 history API,你可能需要使用index.html響應(yīng)404或者問題請求,只需要設(shè)置g historyApiFallback: true即可

自定義值

However, if you have modified output.publicPath in your Webpack configuration, you need to specify the URL to redirect to. This is done using the historyApiFallback.index option

如果你在webpack配置文件中修改了 output.publicPath 值,那么你就需要聲明請求重定向,配置historyApiFallback.index 值。

// output.publicPath: '/assets/'
historyApiFallback: {
 index: '/assets/'
}

Proxy

發(fā)現(xiàn)使用以上方式,并不能完全解決我的問題,總會有路由請求響應(yīng)異常,于是博主繼續(xù)查找更好的解決方案:

點此查看文檔

The proxy can be optionally bypassed based on the return from a function. The function can inspect the HTTP request, response, and any given proxy options. It must return either false or a URL path that will be served instead of continuing to proxy the request.

代理提供通過函數(shù)返回值響應(yīng)請求方式,針對不同請求進行不同處理,函數(shù)參數(shù)接收HTTP請求和響應(yīng)體,以及代理配置對象,這個函數(shù)必須返回false或URL路徑,以表明如何繼續(xù)處理請求,返回URL時,源請求將被代理到該URL路徑請求。

proxy: {
 '/': {
  target: 'https://api.example.com',
  secure: false,
  bypass: function(req, res, proxyOptions) {
   if (req.headers.accept.indexOf('html') !== -1) {
    console.log('Skipping proxy for browser request.');
    return '/index.html';
   }
  }
 }
}

如上配置,可以監(jiān)聽https://api.example.com域下的/開頭的請求(等效于所有請求),然后判斷請求頭中accept字段是否包含html,若包含,則代理請求至/index.html,隨后將返回index.html文檔至瀏覽器。

解決問題

綜合以上方案,因為在webpack配置中修改了output.publicPath為/assets/,所以博主采用webpack-dev-server Proxy代理方式解決了問題:

const PUBLICPATH = '/assets/'
...
proxy: {
 '/': {
  bypass: function (req, res, proxyOptions) {
   console.log('Skipping proxy for browser request.')
   return `${PUBLICPATH}/index.html`
  }
 }
}

監(jiān)聽所有前端路由,然后直接返回${PUBLICPATH}/index.html,PUBLICPATH就是設(shè)置的output.publicPath值。

另外,博主總是習(xí)慣性的聲明,雖然不設(shè)置該屬性也能滿足預(yù)期訪問效果:

historyApiFallback: true

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

相關(guān)文章

  • Ant?Design?組件庫按鈕實現(xiàn)示例詳解

    Ant?Design?組件庫按鈕實現(xiàn)示例詳解

    這篇文章主要介紹了Ant?Design?組件庫按鈕實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪</P><P><BR>
    2022-08-08
  • React組件的生命周期深入理解分析

    React組件的生命周期深入理解分析

    組件的生命周期就是React的工作過程,就好比人有生老病死,自然界有日月更替,每個組件在網(wǎng)頁中也會有被創(chuàng)建、更新和刪除,如同有生命的機體一樣
    2022-12-12
  • react實現(xiàn)動態(tài)增減表單項的示例代碼

    react實現(xiàn)動態(tài)增減表單項的示例代碼

    在做項目的時候,甲方給的信息有限,網(wǎng)頁的備案信息寫成固定的,之后驗收的時候,甲方要求把這個備案信息寫成動態(tài)的,可以自增減,下面通過實例代碼給大家介紹react實現(xiàn)動態(tài)增減表單項的示例,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • react使用useImperativeHandle示例詳解

    react使用useImperativeHandle示例詳解

    這篇文章主要為大家介紹了react使用useImperativeHandle示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • React-Route6實現(xiàn)keep-alive效果

    React-Route6實現(xiàn)keep-alive效果

    本文主要介紹了React-Route6實現(xiàn)keep-alive效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2022-06-06
  • React開發(fā)進階redux saga使用原理詳解

    React開發(fā)進階redux saga使用原理詳解

    這篇文章主要為大家介紹了React開發(fā)進階redux saga使用原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • redux的原理、工作流程及其應(yīng)用方式

    redux的原理、工作流程及其應(yīng)用方式

    這篇文章主要介紹了redux的原理、工作流程及其應(yīng)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • react-pdf實現(xiàn)將pdf文件轉(zhuǎn)為圖片,用于頁面展示

    react-pdf實現(xiàn)將pdf文件轉(zhuǎn)為圖片,用于頁面展示

    這篇文章主要介紹了react-pdf實現(xiàn)將pdf文件轉(zhuǎn)為圖片,用于頁面展示問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 簡單談?wù)凴eact中的路由系統(tǒng)

    簡單談?wù)凴eact中的路由系統(tǒng)

    下面小編就為大家?guī)硪黄唵握務(wù)凴eact中的路由系統(tǒng)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 詳解react應(yīng)用中的DOM DIFF算法

    詳解react應(yīng)用中的DOM DIFF算法

    這篇文章主要介紹了react應(yīng)用中的DOM DIFF算法,幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下
    2021-04-04

最新評論