中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

發布時間:2020-10-21 03:39:02 來源:腳本之家 閱讀:325 作者:Sam_Lii 欄目:web開發

前言: 項目使用vue-cli版本2.9.3 ,vue-router使用webpackChunkName實現按需加載.

vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

BUG描述:該報錯在項目上線一段時間后,有用戶反映頁面無法正常游覽 (后面以問題1/問題2區分)

問題1.導航點擊無法正常跳轉,console打印:Error:Loading chunk {n} failed.

報錯截圖vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

問題2.頁面全白,console打印:Uncaught SyntaxError:Unexpected token <

報錯截圖: vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

經過一番折騰,初步定位問題1在經過build/webpack.prod.conf.jschunkhash打包后的JS文件hash值會有變更,因為每次更新代碼到線上都會刪除舊的dist目錄,將最新的dist目錄copy上傳提供后臺更新. 在更新代碼的這個過程用戶停留在頁面上,當用戶在更新完后重新操作就會導致報錯

vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

問題1解決方法:捕獲路由報錯. (思路來源:https://www.jb51.net/article/147427.htm)

routers.onError((err) => {
 const pattern = /Loading chunk (\d)+ failed/g;
 const isChunkLoadFailed = err.message.match(pattern);
 if (isChunkLoadFailed) {
  let chunkBool = sessionStorage.getItem('chunkError');
  let nowTimes = Date.now();
  if (chunkBool === null || chunkBool && nowTimes - parseInt(chunkBool) > 60000) {//路由跳轉報錯,href手動跳轉
   sessionStorage.setItem('chunkError', 'reload');
   const targetPath = routers.history.pending.fullPath;
   window.location.href = window.location.origin + targetPath;
  }else if(chunkBool === 'reload'){ //手動跳轉后依然報錯,強制刷新
   sessionStorage.setItem('chunkError', Date.now());
   window.location.reload(true);
  }
 }
})

問題2在Network查看js文件加載的時候發現某個js文件Response Headercontent-type異常,正常情況返回content-type: application/javascript. 但是有一個js響應的內容為HTML, js無法識別<符號導致拋出報錯

vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

vue-cli 打包后提交到線上出現 "Uncaught SyntaxError:Unexpected token" 報錯

問題2目前還在與后臺商量如何解決,解決后會更新解決方法分享.有同學遇到同樣的問題可以一起討論或提出更好的解決方案參考學習.★★★

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东丽区| 新野县| 化隆| 高邮市| 抚州市| 富川| 福清市| 科技| 嘉祥县| 本溪市| 邵东县| 前郭尔| 余干县| 天等县| 灵台县| 巩留县| 和田市| 高碑店市| 丽水市| 虞城县| 蚌埠市| 莒南县| 宜黄县| 兖州市| 普定县| 东明县| 康保县| 城市| 长武县| 宁乡县| 启东市| 阿勒泰市| 眉山市| 化德县| 雷山县| 铜山县| 中江县| 怀来县| 东阳市| 长垣县| 贡觉县|