一、兼容ES6

Vue 的核心框架 vuejs 本身,以及官方核心插件(VueRouter、Vuex等)均可以在 ie9 上正常使用。但ie不兼容es6,所以需要安装插件将“Promise”等高级语法转换成ie可以识别的es5。

  报错:ReferenceError: “Promise”未定义,页面空白
  报错:app.js文件报错页面空白,可能是缺少配置文件.babelrc

一、 babel-polyfill
npm install babel-polyfill --save
  在main.js中的最前面引入import 'babel-polyfill'(注:必须引入在最前面,保证所有es6语法都会被解析)
  下载完成后找到build文件夹下的webpack.base.conf.js下的一段代码

module.exports = {
  entry: {
    app: './src/main.js'
  },

替换为

module.exports = {
context: path.resolve(__dirname, '../'),
entry: {
  app: ["babel-polyfill", "./src/main.js"],
}

二、如果引入 babel-polyfill还有一些高级语法没有被编译,配置 .babelrc文件,官网如下: https://www.babeljs.cn/ 根据项目选择引入什么插件,以及如何配置,详情查看官网。

检查根目录下是否有.babelrc文件,如没有自行创建。
.babelrc是Babel的配置文件,放在项目根目录下,使用Babel的第一步就是配置这个文件,该文件主要是对预设(presets)和插件(plugins)进行配置

创建.babelrc文件的方法:
  1.新建一个文件
  2.右键-重新命名-输入.babelrc. (开头和结尾一共两个点)
  3.添加配置代码,

  {
    "presets": [
      ["env", {
        "modules": false,
        "useBuiltIns": "entry"
      }],
    "stage-2"
    ]
  }

配置代码解读:
(1) modules该参数的含义是:启用将ES6模块语法转换为另一种模块类型。将该设置为false就不会转换模块。默认为 ‘commonjs’.
  这样做的目的是:以前我们需要使用babel来将ES6的模块语法转换为AMD, CommonJS,UMD之类的模块化标准语法,但是现在webpack都帮我做了这件事了,所以我们不需要babel来做,因此需要在babel配置项中设置modules为false,因为它默认值是commonjs, 否则的话,会产生冲突。

(2) useBuiltIns是指定哪些内容需要被 polyfill(兼容) 的设置,有三个设置选项

  false - 不做任何操作
  entry - 根据浏览器版本的支持,将 polyfill 需求拆分引入,仅引入有浏览器不支持的polyfill
  usage - 检测代码中 ES6/7/8 等的使用情况,仅仅加载代码中用到的 polyfill

(3) stage-2官方预设(preset), 有两种,一个是按年份(babel-preset-es2017),一个是按阶段(babel-preset-stage-0)。 这主要是根据TC39 委员会ECMASCRPIT 发布流程来制定的。
    因此到目前为止 有4个不同的阶段预设:stage-0,1,2,3以上每种预设都依赖于紧随的后期阶段预设,也就是说stage-0是包括stage-1的,以此类推。
  因此 stage-0包含stage-1/2/3的内容。所以如果我们不知道需要哪个stage-x的话,直接引入stage-0就好了。
  目前一般是使用stage2 (https://babeljs.io/docs/en/babel-preset-stage-2) 该特性规范己经被起草,将会被纳入标准里.

配置完以上两项后,基本可以解决页面空白的问题。

三、网上还有一些其他注意事项,比如安装了新的功能性插件e-chart,地图,或者static目录下有其他js文件(有es6语法) 等,IE 会报错。
这是由于这些第三方插件的底层也有es6代码,没有被编译,个人实践后认为是由于没有将babel-polyfill引入在页面最顶部导致的。但如引入在顶部还报错,请参考以下解决方案:
1.找到webpack.base.config.js
2.

{
  test: /\.js$/,
  loader: 'babel-loader',
  include: [
  resolve('src'),
  resolve('test'),
  resolve('static'),
  resolve('node_modules/webpack-dev-server/client')
  resolve('node_modules/echarts')
  ]
}

二、兼容axios

  一、如果只需要兼容axios的话,可以只用 es6-promise ,不引用babel-polyfill,安装方法如下:

  npm install es6-promise --save
  import promise from 'es6-promise';
  promise.polyfill();

二、IE浏览器缓存问题,导致axios接口不重新请求,页面内容不刷新
  解决方案: axios请求上加时间戳,使每次都是参数不同的新请求

  1、找到项目中对axios进行封装的文件
  2.找到post和get方法,修改里面的参数,以post请求为例,原参数为data: ...param,改为如下第7行所示

//post请求
  post(url, param) {
    return new Promise((resolve, reject) => {
      axios({
    method: 'post',
    url,
    data: {
      t: Date.parse(new Date()),
      ...param
    },
    cancelToken: new CancelToken(c => {
      cancel = c
    })
    }).then(res => {
    resolve(res)
      }).catch((error) => {
    reject(error);
      })
    })
  }

3.问题分析:
这个页面不刷新的问题,一开始以为是v-router的缓存机制导致的,尝试在每次跳转路由时加时间戳,但并没有解决问题,最后才发现是axios的问题。
由此反向推理,如果将axios加上时间戳,不能解决问题,请重新检查是否有v-router的,或者请求方式为history,等缓存机制的影响。

vue项目兼容ie的更多相关文章

  1. 如何让vue项目兼容IE浏览器

    一般来说项目开发到后期都需要做各种兼容性处理例如:360.IE9以上.QQ浏览器....等等 那么现在来介绍一个工具 babel-cli 跟 babel-preset-es2015 babel-cli ...

  2. Vue项目兼容IE浏览器

    转载:https://blog.csdn.net/qq_24956515/article/details/77527668 Vue项目部署到服务器后,通常除IE浏览器外其他都正常,而IE浏览器会报这么 ...

  3. vue项目兼容es6语法跟IE浏览器

    要安装babel-polyfill和es6-promise.用来兼容ie和es6: 附赠链接下载:https://babeljs.io/docs/en/6.26.3/babel-polyfill:ht ...

  4. IE显示 “Promise”未定义,vue项目兼容ie的两种方案

    第一种方法: 直接在html中加入js链接: <script src = "https://cdn.polyfill.io/v2/polyfill.min.js">&l ...

  5. 从 ie10浏览器下Symbol 未定义的问题 探索vue项目如何兼容ie低版本浏览器(ie9, ie10, ie 11 )

    问题:     vue项目在ie11下一片空白并报Symbol 未定义的错 原因:     ie10浏览器解析不了es6的语法,需要我们使用babel(Babel是一种工具链,主要用于将ECMAScr ...

  6. vue 项目在 IE11 里呈现空白,不兼容的问题解决方案

    我用vue 2.6.11版本编写的项目,在谷歌浏览器上运行的好好地,但是放到ie11浏览器上却是一片空白. 这个问题遇到的时候,我是蒙蔽了,抓紧去搜了搜百度,百度上的答案倒是都很统一. 都是说ie不兼 ...

  7. vue项目目录介绍

    Vue项目目录 初始化项目 vue init webpack []projectname] cd [projectname] npm install vue run dev 目录树 +---build ...

  8. 如何快速把 Vue 项目升级到 webpack3

    由于 webpack3升级后,新增了 Scope Hositing(作用域提升) 功能,据说是对 js的性能提升很大.因此,我们做了一个测试对比,就是 webpack3和 webpack1/2 的性能 ...

  9. 去除vue项目中的#及其ie9兼容性

    一.如何去除vue项目中访问地址的# vue2中在路由配置中添加mode(vue-cli创建的项目在src/router/index.js) export default new Router({ m ...

随机推荐

  1. Python 获取任意周期开盘日

    import json import requests import datetime import tushare as ts cal_dates = ts.trade_cal() today=da ...

  2. 用Jenkins集成ios项目设置多scheme,同一代码自动输出多个环境包 实现便捷切换API环境

    Jenkins 安装使用参考我的博客http://www.cnblogs.com/zhujin/p/9064820.html Xcode 配置:说明 一个schema 对应一套环境(如生产,测试),一 ...

  3. stand up meeting 11/25/2015 暨sprint2总结

    今天在课堂上进行了小组项目的阶段性总结,这两天小组内也是频繁的开会,具体细节我们已经反复核查,具体不表~ sprint2个人工作总结: 冯晓云:完成了必应词典在线查词api的调用和网络状况的检测:完成 ...

  4. HTTPoxy漏洞(CVE-2016-5385)复现记录

    漏洞介绍: httpoxy是cgi中的一个环境变量:而服务器和CGI程序之间通信,一般是通过进程的环境变量和管道. CGI介绍 CGI 目前由 NCSA 维护,NCSA 定义 CGI 如下:CGI(C ...

  5. linux下文本三剑客之sed

    继上一篇对正则表达式以及linux三剑客grep的讲解后,这一篇对sed重点介绍. 一.sed简介   sed表示流编辑器(Stream Editor).这是一个简单但功能强大的工具,分析文本,并无缝 ...

  6. 痞子衡嵌入式:大话双核i.MXRT1170之Cortex-M7与Cortex-M4互相激活之道

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是恩智浦i.MXRT1170上Cortex-M7与Cortex-M4内核互相激活的方法. 痞子衡最近在深耕i.MXRT1170这颗划时代的 ...

  7. DFS(单词方阵)

    思路: 先把地图二维字符数组存进去之后,遍历寻找到一个‘y’,然后我们可以设置一个八个方向的方向数组,让‘y’的坐标,遍历加上方向坐标,找到’i‘然后沿着这个方向,dfs下去,每次寻找到正确的,然后建 ...

  8. 备忘录模式 (c++实现)

    模式定义 备忘录(Memento): 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可以将该对象恢复到原先保存的状态. 模式动机 备忘录模式比较适用于功能比较复 ...

  9. LeetCode7-ReverseInteger

    LeetCode7-ReverseInteger LeetCodeeasyOverflow 题目 题目所在链接为 LeetCode-7:ReverseInteger 题目描述 给出一个32位的有符号整 ...

  10. 重识TCP/IP协议族与HTTP基础

    不忘初心 砥砺前行, Tomorrow Is Another Day ! 本文概要: TCP/IP协议族的网络分层 TCP三次握手四次挥手 Http简介 报文结构 Http的请求方法及状态码 常用的H ...