vue检测是不是360浏览器兼容模式_Vue项目兼容IE11
Vue 不支持 IE8 及以下版本,因为 Vue 使用了 IE8 无法模拟的 ECMAScript 5 特性。但对于 IE9+,Vue 底层是支持。
由于开发过程中,我们经常会使用一些第三方插件或组件,对于这些组件,有时我们需要做一些处理。下述主要阐述如何使用 vue-cli3 脚手架搭建的工程支持 IE11。
现象
IE11 打开 Vue 工程(Vue CLI)构建而来出现空白页,控制台告警、报错。
如:
- DOM7011: 此页上的代码禁用了反向和正向缓存
- HTML1300:进行了导航
- app.js 各种语法错误
browserslist
项目中 package.json
文件里的 browserslist
字段 (或一个单独的 .browserslistrc
文件),指定了项目的目标浏览器的范围。这个值会被 @babel/preset-env 和 Autoprefixer 用来确定需要转译的 JavaScript 特性和需要添加的 CSS 浏览器前缀。
- @babel/preset-env:将你使用最新 JavaScript 语法,灵活的转化为目标浏览器所支持的 polyfill。
- Autoprefixer:PostCSS 插件,为浏览器增加前缀。
.browserslistrc
> 1%
last 2 versions
not ie < 11
Polyfill
默认的 Vue CLI 项目会使用 @vue/babel-preset-app,它通过 @babel/preset-env
和 browserslist
配置来决定项目需要的 polyfill。
默认情况下,它会把 useBuiltIns: 'usage'
传递给 @babel/preset-env
,这样它会根据源代码中出现的语言特性自动检测需要的 polyfill。这确保了最终包里 polyfill 数量的最小化。然而,这也意味着如果其中一个依赖需要特殊的 polyfill,默认情况下 Babel 无法将其检测出来。
Vue CLI 文档 中,提供了三种方式:
- 如果该依赖基于一个目标环境不支持的 ES 版本撰写: 将其添加到
vue.config.js
中的transpileDependencies
选项。这会为该依赖同时开启语法转换和根据使用情况检测 polyfill。 - 如果该依赖交付了 ES5 代码并显式地列出了需要的 polyfill: 你可以使用
@vue/babel-preset-app
的 polyfills 选项预包含所需要的 polyfill。注意es6.promise
将被默认包含,因为现在的库依赖 Promise 是非常普遍的。
// babel.config.js
module.exports = {presets: [['@vue/app', {polyfills: ['es6.promise','es6.symbol']}]]
}
提示:我们推荐以这种方式添加 polyfill 而不是在源代码中直接导入它们,因为如果这里列出的 polyfill 在 browserslist 的目标中不需要,则它会被自动排除
- 如果该依赖交付 ES5 代码,但使用了 ES6+ 特性且没有显式地列出需要的 polyfill (例如 Vuetify):请使用 useBuiltIns: 'entry' 然后在入口文件添加 import '@babel/polyfill'。这会根据 browserslist 目标导入所有 polyfill,这样你就不用再担心依赖的 polyfill 问题了,但是因为包含了一些没有用到的 polyfill 所以最终的包大小可能会增加。
我们采用了最简单最直接(但是性能不是最好)的第 3 种方式!
第一步: 在 babel 的相关配置文件(babel.config.js、.babelrc 或 package.json 的 babel 字段任一)中,增加 "useBuiltIns": "entry"
信息。babel 7 版本以后,会有差异 -- Here
babel.config.js
{"presets": [["@babel/preset-env",{"useBuiltIns": "entry"}]]
}
- If
useBuiltIns: 'usage'
is specified in.babelrc
then do not include@babel/polyfill
in eitherwebpack.config.js
entry array nor source. Note,@babel/polyfill
still needs to be installed. - If
useBuiltIns: 'entry'
is specified in.babelrc
then include@babel/polyfill
at the top of the entry point to your application viarequire
orimport
as discussed above. - If
useBuiltIns
key is not specified or it is explicitly set withuseBuiltIns: false
in your .babelrc, add@babel/polyfill
directly to the entry array in yourwebpack.config.js
.
{"presets": [["@babel/preset-env",{"useBuiltIns": "entry"}]]
}
!!! 网上信息比较混乱,经常出现几种方式混用,并不合理!
第二步: 安装 '@babel/polyfill' ,并在入口文件添加 import '@babel/polyfill'
$ npm install --save @babel/polyfill
main.js
import '@babel/polyfill'
注意,Babel 7.4.0 以后,该包已被弃用(deprecated)。官方推荐使用 core-js/stable
和 regenerator-runtime/runtime
替代。 -- @babel/polyfill
至此,我们已按照官方要求做了配置,重新启动项目,发现依然不行!!
transpileDependencies
默认情况下 babel-loader
会忽略所有 node_modules
中的文件。如果你想要通过 Babel 显式转译一个依赖,可以在 transpileDependencies 选项中列出来。
下一步:使用 babel 对 elementUI、vuex(需要 Promise polyfill -- Here) 进行转换。
按照 Vue CLI 提供的 3 种方案的第 1种:
如果该依赖基于一个目标环境不支持的 ES 版本撰写: 将其添加到
vue.config.js
中的transpileDependencies
选项。这会为该依赖同时开启语法转换和根据使用情况检测 polyfill。
vue.config.js
transpileDependencies: [/node_modules[/](element-ui|vuex|)[/]/],
根据你的项目实际情况,此处 element-ui 可能不需要
proxy
针对 Proxy 对象进行 polyfill。
下一步: 在 index.html
文件中引入 es6-proxy-polyfill.js
<script src = "https://cdn.jsdelivr.net/npm/proxy-polyfill@0.3.0/proxy.min.js"></script>
根据项目实际情况,看是否有必要引入。如果引入,建议下载到本地,再引入。
至此,项目终于不是空白页了!!
但是,出现了大量排版错误!
css polyfill
由于我们项目中,大量使用了 CSS var()
,IE11 不兼容导致,思路相同,寻找相应的 polyfill 即可。这里我们使用了 css-vars-ponyfill
$ npm install --save css-vars-ponyfill
main.js
import cssVars from 'css-vars-ponyfill'
cssVars({})
大功告成!
总结
总之,所有的处理都是围绕转换成 IE11 可以兼容的方式去处理。对于 JavaScript 语法,即是对 babel 的控制;对于 CSS 语法,需要特定分析。
IE 微软已不再维护,也希望我们所有的前端小伙伴可以早日脱离这苦海!
欢迎关注 「 Super 前端 」微信公众号
版权声明:
本文原创自我的博客:李刚的学习专栏
vue检测是不是360浏览器兼容模式_Vue项目兼容IE11相关推荐
- vue检测是不是360浏览器兼容模式_Vue项目 IE/360浏览器兼容模式下打开空白的问题...
记一次bug解决 bug发现 项目不复杂,就是一个基于vue-cli3搭建的pc端项目 在开发进入后半段的时候发现在360浏览器兼容模式先显示空白而且没有报错,此类问题之前我写react在低版本的qq ...
- vue检测是不是360浏览器兼容模式_vue开发之不同浏览器的类型判断
一.通过navigator.userAgent来进行浏览器类型判断 定义和用法 userAgent 属性是一个只读的字符串,声明了浏览器用于 HTTP 请求的用户代理头的值. 一般来讲,它是在 nav ...
- vue检测是不是360浏览器兼容模式_360安全浏览器兼容模式无法访问vue怎么解决?...
360安全浏览器兼容模式无法访问vue怎么解决?下面本篇文章给大家介绍一下vue在IE和360兼容模式下无法显示问题.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. 360兼容模式下 ...
- 开发网站时解决360浏览器的兼容性问题,兼容模式打不开,让网页默认为极速模式打开
360浏览器打开网页默认是兼容模式,导致有些网页打不开, 可以在网页头部加上代码,默认改为为极速模式打开,就正常了: <meta http-equiv="X-UA-Compatible ...
- 设置网页默认为360浏览器极速模式打开
设置网页默认为360浏览器极速模式打开 在head标签中添加一行代码: <html> <head> <meta name="renderer" con ...
- 360浏览器极速模式自动_浏览器正在为网站带来自动暗模式
360浏览器极速模式自动 nalyvme/Shutterstock.comnalyvme / Shutterstock.com Dark mode is now everywhere, includi ...
- Vue检测当前是否处于mock模式
Vue检测当前是否处于mock模式 1.在main.js中声明全局变量: import Vue from 'vue'/* 全局变量 */ var GLOBAL_VARIABLE = { isMockM ...
- html文档兼容模式,怎么取消兼容模式 excel出现兼容模式怎么取消
word文档显示兼容模式怎么取消 word怎么关闭兼容模式,Excel如何以兼容模式打开早期版本的工作簿 只需要把当前的文件重新另存为xlsx格式的文件即可. Excel的兼容模式是针对旧版的xls格 ...
- ie10和ie11支持html5吗,IE11兼容模式和IE10兼容模式有什么区别
不仅有一个"兼容模式",但有几个. v8和v11之间的所有IE版本都提供兼容模式.早在IE7的早期版本中就有一个兼容模式.因此,IE8提供IE7兼容模式,IE9提供IE8和IE7兼 ...
- IE兼容模式及客户端兼容模式、服务器端兼容模式设置
IE兼容模式: 为了帮助确保网页在将来的 Internet Explorer 版本中具有一致的外观, Internet Explorer 8 引入了文档兼容性.文件兼容性用于定义IE如何渲染网页 ...
最新文章
- python如何安装panda数据库_python怎么安装pandas
- 使用diamond2的一些问题的解决
- android中解压文件
- JS流程控制语句 二选一 (if...else语句) 语法: if(条件) { 条件成立时执行的代码} else {条件不成立时执行的代码}...
- 7-23 还原二叉树 (25 分)(分析加详解)
- 中文字符频率统计python_python统计字符串出现最多的字母及其出现次数
- 06-01 搭建持续集成平台 Jenkins
- Android 网络协议
- matlab广州等温线地形图,MATLAB 画等温线.doc
- 【原】Coursera—Andrew Ng机器学习—Week 9 习题—异常检测
- 数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器(转)...
- Spring Boot项目能之前能正常跑,安装禅道后突然就不行了报错Unknown database “数据库名“
- Javascript高级程序设计——函数声明与函数表达式的区别
- C++调用编译好的darknet来进行物体监测
- 子进程 已安装 pre-removal 脚本 返回了错误号 1或2 与 子进程 已安装 post-installation 脚本 返回了错误号 1或2
- 彻底禁止电脑弹出广告的方法(以2345好压为例)
- 超级账本HyperLedger的Fabric-CA的使用(两个组织一个Orderer三个Peer),带视频演示
- 计算机 系统 声音问题 有回声
- 微信小程序操作es简单搜索
- 服务器搭建微信会员卡系统,智络会员管理系统如何与微信对接