vue+axios+vue-router兼容ie9

參考:Vue 兼容 ie9 的全面解決方案

前序

項目突然要求兼容ie9...可是用到的技術棧對ie9似乎不是很友好,綜合上面的參考的文章,需要添加以下內容:

1.ES6兼容

ES6兼容的話,需要安裝特定的模塊,執行 命令npm isntall babel-polyfill,然后在文件配置:

babel-polyfill配置

2.vue-router的history模式兼容

因為vue-router對于ie9默認是退回到hash模式的,所以在new router的時候,需要設置fallback:false(默認值為true)

fallback:當瀏覽器不支持 history.pushState 控制路由是否應該回退到 hash 模式。默認值為 true。
在 IE9 中,設置為 false 會使得每個 router-link 導航都觸發整頁刷新。它可用于工作在 IE9 下的服務端渲染應用,因為一個 hash 模式的 URL 并不支持服務端渲染。
配置示例:

const router = new Router({
  fallback: false,
  base: "/test/",
  mode: "history",
  routes: []
})

3跨域

盡管后端已經配置了CORS,但是在ie9情況下,CORS無效,所以需要nginx設置反向代理.
參考:vue項目部署方式:tomcat部署和nginx部署

4設置了nginx反向代理仍然無法獲取response.data

設置了反向代理,正常發出和獲取響應,但是response.data卻為空值,響應值被存到response.request.responseText中.這時候要利用axios.interceptors.response適當添加兼容代碼:

Axios.interceptors.response.use(
  function(response) {
    //判斷是否有是ie9
    if (isIE9()) {
      //特殊處理response
      if (response.status == 200 && response.request) {
        if (
          response.request.responseType === "json" &&
          response.request.responseText
        ) {
          response.data = JSON.parse(response.request.responseText);
          console.log("repsonse", response);
        }
      }
    }
    return response;
  },
  function(error) {
    if (error.response) {
         // 對響應錯誤做點什么
    console.log("error", error);
    return Promise.reject(error);
  }
);

function isIE9() {
  if (
    navigator.appName == "Microsoft Internet Explorer" &&
    parseInt(
      navigator.appVersion
        .split(";")[1]
        .replace(/[ ]/g, "")
        .replace("MSIE", "")
    ) <= 9
  ) {
    return true;
  }
  return false;
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,182評論 6 543
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,489評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,290評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,776評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,510評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,866評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,860評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,036評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,585評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,331評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,536評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,058評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,754評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,154評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,469評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,273評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,505評論 2 379

推薦閱讀更多精彩內容

  • 響應式布局的理解 響應式開發目的是一套代碼可以在多種終端運行,適應不同屏幕的大小,其原理是運用媒體查詢,在不同屏幕...
    懶貓_6500閱讀 800評論 0 0
  • 前言部分 一、跨域是什么? 跨域是指一個域下的文檔或腳本試圖去請求另一個域下的資源(廣義的)。 廣義的跨域場景有以...
    爆發吧小宇宙閱讀 3,311評論 0 12
  • 前言 背景情況 vue - 2.5.11 vue-cli 使用模板 webpack-simple http請求:a...
    Terry05閱讀 6,238評論 2 18
  • 又是兩天沒有寫字,這里想講一下這兩天發生的一些事情。奶奶生病,我每天都要帶著寶寶去陪一下她,天氣很冷氣溫零下,第一...
    露露Yao閱讀 258評論 1 1
  • 人生總要有一次鄭重的詢問“我是誰”。 離婚一年整兩個月,一個人的生活孤單又自由。當然,一開始也很失落和無奈...
    別讓我不安閱讀 175評論 0 0