国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue路由history模式解決404問題的幾種方法

來源:懂視網 責編:小采 時間:2020-11-27 22:06:45
文檔

Vue路由history模式解決404問題的幾種方法

Vue路由history模式解決404問題的幾種方法:問題背景: vue-router 默認是hash模式,使用url的hash來模擬一個完整的url,當url改變的時候,頁面不會重新加載。但是如果我們不想hash這種以#號結尾的路徑時候的話,我們可以使用路由的history的模式。比如如下網址:使用hash模式的話,那么訪問變成
推薦度:
導讀Vue路由history模式解決404問題的幾種方法:問題背景: vue-router 默認是hash模式,使用url的hash來模擬一個完整的url,當url改變的時候,頁面不會重新加載。但是如果我們不想hash這種以#號結尾的路徑時候的話,我們可以使用路由的history的模式。比如如下網址:使用hash模式的話,那么訪問變成

問題背景:

vue-router 默認是hash模式,使用url的hash來模擬一個完整的url,當url改變的時候,頁面不會重新加載。但是如果我們不想hash這種以#號結尾的路徑時候的話,我們可以使用路由的history的模式。比如如下網址:使用hash模式的話,那么訪問變成 http://localhost:8080/bank/page/count/#/ 這樣的訪問,如果路由使用 history的話,那么訪問的路徑變成 如下:http://localhost:8080/bank/page/count 這樣的了;

不過history的這種模式需要后臺配置支持。比如:當我們進行項目的主頁的時候,一切正常,可以訪問,但是當我們刷新頁面或者直接訪問路徑的時候就會返回404,那是因為在history模式下,只是動態的通過js操作window.history來改變瀏覽器地址欄里的路徑,并沒有發起http請求,但是當我直接在瀏覽器里輸入這個地址的時候,就一定要對服務器發起http請求,但是這個目標在服務器上又不存在,所以會返回404

怎么解決呢?我們現在可以把所有請求都轉發到 http://localhost:8080/bank/page/index.html上就可以了。

解決方案:

對于VUE的router[mode: history]模式在開發的時候,一般都不出問題。是因為開發時用的服務器為node,Dev環境中自然已配置好了。

但對于放到nginx下運行的時候,自然還會有其他注意的地方。總結如下:

在nginx里配置了以下配置后, 可能首頁沒有問題,但鏈接其他會出現(404)

    location / {
 root D:\Test\exprice\dist;
 index index.html index.htm;
 try_files $uri $uri/ /index.html;
 add_header 'Access-Control-Allow-Origin' '*';
 add_header 'Access-Control-Allow-Credentials' 'true';
 add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
 add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
 }
 
 location ^~/api/ {
 proxy_pass http://39.105.109.245:8080/;
 }

為了解決404,需要通過以下兩種方式:

1、官網推薦

location / {
  root D:\Test\exprice\dist;
  index index.html index.htm;
  try_files $uri $uri/ /index.html;

2、匹配errpr_page

location /{
  root /data/nginx/html;
  index index.html index.htm;
  error_page 404 /index.html;
}

3、 (vue.js官方教程里提到的https://router.vuejs.org/zh-cn/essentials/history-mode.html)

 server {
 listen 8888;#默認端口是80,如果端口沒被占用可以不用修改
 server_name localhost;
 root E:/vue/my_project/dist;#vue項目的打包后的dist
 location / {
 try_files $uri $uri/ @router;#需要指向下面的@router否則會出現vue的路由在nginx中刷新出現404
 index index.html index.htm;
 }
 #對應上面的@router,主要原因是路由的路徑資源并不是一個真實的路徑,所以無法找到具體的文件
 #因此需要rewrite到index.html中,然后交給路由在處理請求資源
 location @router {
 rewrite ^.*$ /index.html last;
 }
 #.......其他部分省略
 }

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue路由history模式解決404問題的幾種方法

Vue路由history模式解決404問題的幾種方法:問題背景: vue-router 默認是hash模式,使用url的hash來模擬一個完整的url,當url改變的時候,頁面不會重新加載。但是如果我們不想hash這種以#號結尾的路徑時候的話,我們可以使用路由的history的模式。比如如下網址:使用hash模式的話,那么訪問變成
推薦度:
標簽: VUE 路由 兩種
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产成人精品一区二区视频 | 亚洲乱色 | 亚洲欧美天堂 | 国产成人精品一区二区免费视频 | 国产精品第1页在线观看 | 国产精品一区欧美日韩制服 | 国内精品久久久久久久97牛牛 | 大香伊人久久 | 国产不卡视频在线播放 | 亚洲国产成人精品一区二区三区 | 欧美激情网站 | 久久久亚洲欧美综合 | 亚洲狼人香蕉香蕉在线28 | 欧美日韩国产另类一区二区三区 | 欧美亚洲国产精品 | 国产a区| 国产欧美日韩在线观看 | 日韩经典欧美一区二区三区 | 国产亚洲欧美一区二区三区 | 国产亚洲一欧美一区二区三区 | 中日韩美中文字幕 | 91香蕉国产亚洲一区二区三区 | 无毛片| 国内精品一区二区 | 欧美色图亚洲激情 | 国产欧美亚洲精品a | 大黄毛片 | 亚洲国产成人精品一区91 | 国产精品国产三级国产 | 国产高清在线免费 | 五月天婷婷在线视频 | 国产a久久精品一区二区三区 | 99精品视频在线观看免费 | 欧美日韩高清不卡免费观看 | 亚洲精品高清国产一久久 | 国产毛片视频 | 在线一区观看 | 五月天婷婷在线观看 | 欧美日韩国产va另类试看 | 亚洲国产欧美91 | 国产精品一区二区手机在线观看 |