位置: IT常识 - 正文

Vue中 引入使用 babel-polyfill 兼容低版本浏览器(vuecdn方式引入)

编辑:rootadmin
Vue中 引入使用 babel-polyfill 兼容低版本浏览器

推荐整理分享Vue中 引入使用 babel-polyfill 兼容低版本浏览器(vuecdn方式引入),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vuecdn方式引入,vuecdn方式引入,vue的引入,vue引用axios,vue的引入,vue引入插件方法,vue中引入fs,vue引用vue,内容如对您有帮助,希望把文章链接给更多的朋友!

注意:本文主要介绍的 vue-cli 版本:3.x, 4.x; 最近在项目中使用 webpack 打包后升级,用户反馈使用浏览器(chrome 45)访问白屏。经过排查发现:由于 chrome 45 无法兼容 ES6 语法导致的,因此需要将项目中的 ES6 语法转 ES5 语法。

1. 兼容低版本浏览器方法

1.1 安装 babel-polyfill

babel-polyfill npm地址

npm i babel-polyfill

1.2 引入 方式一(推荐):main.js 顶部第一行

import 'babel-polyfill';

方式二:vue.config.js 中,在 chainWebpack 内添加以下代码

chainWebpack: config => { config.entry('main').add('babel-polyfill') config.entry.app = ['babel-polyfill', './src/main.js']}Vue中 引入使用 babel-polyfill 兼容低版本浏览器(vuecdn方式引入)

1.3(新增)在 babel.config.js 中配置

module.exports = { presets: [ ['@vue/app', { polyfills: [ 'es6.promise', 'es6.symbol', 'es6.array.iterator', 'es6.object.assign', ], useBuiltIns: 'entry', }], ],}

1.4 在 vue.config.js (新增)配置 transpileDependencies 如果还引入了其他插件而该插件内部也存在ES6写法,则需要将这些插件的 ES6 转换成 ES5,使用 transpileDependencies 直接将需要转换的插件放入。

transpileDependencies: [ 'element-ui', 'vant', 'js-cookie', 'vxe-table', 'xe-utils','vue-virtual-scroll-list','vue-socket.io' ],

vue-cli 官方文档中 transpileDependencies 说明

补充说明如安装配置 babel-polyfill 后仍无法兼容低版本浏览器,可适当降级 babel-polyfill 的版本;如使用 cnpm 安装依赖,可能会导致 transpiledependencies 无效,具体原因还未深究。可直接将 node_modules 全部删掉,重新使用 npm 安装所有依赖后,再次重新打包,目前问题已解决;vue-cli 使用 wokrer-loader 加载 web woker 时,使用 npm run build 有很大机率会打包失败:(报错:Syntax Error: Thread Loader (Worker 4) The “from” argument must be of type string. Received undefined)。原因 :thread-loader 与 worker-loader 有冲突。解决: vue.config.js 中配置 parallel: false 。构建正式环境关闭thread-loader。2. vue-cli 2.x 中配置 babel 转换

@babel/core:babel 的核心库 必引,一切 babel 转换操作都基于 @babel/core,因为它包含了编译的 transform 方法

npm install --save-dev @babel/core

@babel/polyfill:用于模拟完整的 ES2015+ 环境 注意:–save 而非 --save-dev,因为这是需要在源码之前运行的 polyfill;

npm install --save @babel/polyfill

安装之后,在项目入口 main.js 引入 @babel/polyfill 即可;

babel-loader:webpack 配置 loader 转换 babel-loader 允许使用 Babel 和 webpack 来转译 JavaScript 文件

npm install --save-dev babel-loader

webpack.base.config.js 文件中配置

module.exports = { module: { rules: [ { test: /\.js$/, loader: 'babel-loader', include: [resolve('src')] } ] }}

通过以上配置即可达到在 vue-cli 2.x 中进行 babel 转换

拓展:关于 Babel 简介

Babel 中文官方文档

Babel 是一个工具链,主要用于将采用 ECMAScript 2015+ 语法编写的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中。下面列出的是 Babel 能为你做的事情:1. 语法转换;2. 通过 Polyfill 方式在目标环境中添加缺失的特性 (通过引入第三方 polyfill 模块,例如 core-js);3. 源码转换(codemods);

本文链接地址:https://www.jiuchutong.com/zhishi/297483.html 转载请保留说明!

上一篇:Vue3报错:Property “xxx“ was accessed during render but is not defined on instance.(vue property decorator)

下一篇:CSS — 导航栏篇(一)(div+css导航栏)

  • 印花税计入税金及附加还是应交税费
  • 进项税额转出会计分录月末如何结转
  • 税盘是干什么用的
  • 公允价值变动损益
  • 一般纳税人结转增值税
  • 费用报销怎么做账务处理
  • 什么是一般公共财政预算收入
  • 稽查查补的税款用什么时候的税率表示
  • 申报个税人员金额一般
  • 月销售额不超过10万
  • 企业所得税申报表A类
  • 境外企业转让非居民企业
  • 应付账款以前年度挂错
  • 贴现利息的计算题
  • 零售商品收入会计分录
  • 发票开具丢失后如有罚款怎么处理?
  • 境外公司付款给国内公司人民币
  • 组织机构代码证过期
  • 工资为负数需要给公司吗
  • 事业单位事业收入和经营收入要上缴财政
  • 出口退免税资格备案
  • 代持的股份
  • 进口商品关税调整
  • 怎样结转销售成本会计分录
  • 职工福利费支付范围
  • win7系统鼠标键盘
  • eclipse 4.19
  • 委托代销商品的代销费用
  • 跨年发票能不能开
  • 减征增值税会计处理
  • 工程施工会计做账流程及会计分录
  • react的高阶组件理解
  • 在报税显示缺少税种信息
  • uniapp使用高德地图直接进行导航
  • 尚品汇在哪
  • 开源ei
  • redis常见问题解决
  • javascript基础编程
  • shift命令 向左移动参数
  • 残保金工资标准
  • 定额发票和增值税发票
  • 期末结转会计分录模板
  • 一般纳税人购进免税农产品如何抵扣进项税额
  • 收回多发的工资在上缴财政,可以用应缴财政款科目吗
  • 母公司的资质怎样才能转给子公司
  • 汽车租赁发票账务怎么开
  • 报销单的经办人是什么意思
  • 购买软件多少钱进无形资产
  • 一般纳税人企业要交哪些税
  • 电子承兑汇票转给下家
  • 预付账款期末可能有余额吗
  • 工程检测单位
  • 外经证是怎么样的
  • 工伤保险待遇是否属于劳动争议
  • 金税系统怎么填写开票信息
  • 坏账准备纳税调增吗
  • 废品损失明细账应选择三栏式
  • mysql 5.7.5 m15 winx64.zip安装教程
  • 微软公布新企业AI产品定价 股价应声涨至盘中纪录高位
  • 怎么用老毛桃u盘装win7系统 老毛桃u盘装win7系统教程图解
  • csinject.exe是什么程序的进程 csinject进程是安全的吗
  • win 8.1激活
  • win10输入框在哪里
  • linux acl设置
  • windows怎么更改网络状态
  • win7 64位旗舰版电脑鼠标如何才能设置成左手操作?设置鼠标为左手操作的方法
  • 怎么免费升级win10系统
  • win7系统无wifi连接
  • 列举css的三种应用方式
  • awk中RS、ORS、FS、OFS的区别和联系小结
  • unicode和utf–8 编码
  • node. js教程
  • bootstrap与Jquery UI 按钮样式冲突的解决办法
  • javaScript parseInt字符转化为数字函数使用小结
  • eventbus threadmode
  • js拖拽排序实现思路
  • 三证合一后还有税务登记证吗?
  • 个人外汇收入申报
  • 城市基础设施配套费由哪个部门收取
  • 地方税务局分局局长级别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设