位置: 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导航栏)

  • 计算器的开机键是什么字母组成的(计算器的开机键是哪个)

    计算器的开机键是什么字母组成的(计算器的开机键是哪个)

  • 苹果笔记本保修几年(苹果笔记本保修期多久)

    苹果笔记本保修几年(苹果笔记本保修期多久)

  • 苹果xr短信能发视频吗(iphone xr不能发短信)

    苹果xr短信能发视频吗(iphone xr不能发短信)

  • 打电话用户正忙是什么意思(打电话用户正忙短信通知他)

    打电话用户正忙是什么意思(打电话用户正忙短信通知他)

  • 文档已被其他应用程序锁定(文档已被其他应用锁定)

    文档已被其他应用程序锁定(文档已被其他应用锁定)

  • 闪电接口检测到液体怎么回事(闪电接口检测到液体请断开连接以晾干接口)

    闪电接口检测到液体怎么回事(闪电接口检测到液体请断开连接以晾干接口)

  • oppo开了OTG读不出来

    oppo开了OTG读不出来

  • 通过赞赏码能找到微信吗(通过赞赏码能找到抖音吗)

    通过赞赏码能找到微信吗(通过赞赏码能找到抖音吗)

  • 老年机开不了机是什么原因(老年机黑屏开不了机怎么办)

    老年机开不了机是什么原因(老年机黑屏开不了机怎么办)

  • 1673是iPad几(ipad型号1673)

    1673是iPad几(ipad型号1673)

  • 安卓手机内存不足解决办法(安卓手机内存不足,怎样扩大手机内存?)

    安卓手机内存不足解决办法(安卓手机内存不足,怎样扩大手机内存?)

  • 荣耀30pro的屏幕是哪家的(荣耀30pro的屏幕刷新率是多少hz)

    荣耀30pro的屏幕是哪家的(荣耀30pro的屏幕刷新率是多少hz)

  • 咸鱼为什么别人付不了款(咸鱼为什么别人发的东西不会违规)

    咸鱼为什么别人付不了款(咸鱼为什么别人发的东西不会违规)

  • 手机淘宝怎么查积分(手机淘宝怎么查看交易快照)

    手机淘宝怎么查积分(手机淘宝怎么查看交易快照)

  • 微博加入黑名单会怎样(微博加入黑名单的人还能看见我的微博吗)

    微博加入黑名单会怎样(微博加入黑名单的人还能看见我的微博吗)

  • 国内手机卡在国外能用吗(国内手机卡在国外接电话要钱吗)

    国内手机卡在国外能用吗(国内手机卡在国外接电话要钱吗)

  • 手机wps怎么复制(手机wps怎么复制表格到另一个文档)

    手机wps怎么复制(手机wps怎么复制表格到另一个文档)

  • 小米手环3有水雾怎么办(小米手环3有水雾怎么解决)

    小米手环3有水雾怎么办(小米手环3有水雾怎么解决)

  • 苹果手机怎么清空短信(苹果手机怎么清楚软件里的缓存)

    苹果手机怎么清空短信(苹果手机怎么清楚软件里的缓存)

  • 网络后门的功能是(网络后门的功能是a是吧)

    网络后门的功能是(网络后门的功能是a是吧)

  • 苹果xr声音小怎么调(苹果xr声音小怎么弄)

    苹果xr声音小怎么调(苹果xr声音小怎么弄)

  • i5 8500无法安装win7系统的解决方法(i5 8500装win10)

    i5 8500无法安装win7系统的解决方法(i5 8500装win10)

  • 如何正确使用好笔记本电池(如何正确使用好薪酬调查结果)

    如何正确使用好笔记本电池(如何正确使用好薪酬调查结果)

  • 什么手机最薄(什么手机最薄最有手感)

    什么手机最薄(什么手机最薄最有手感)

  • 车船税每年都要交吗,一般是多少钱交强险可以晚交吗
  • 所有者权益分配流程
  • 印花税的计提
  • 汇算清缴退款怎么入账
  • 简易征收开出去的票可以抵扣吗
  • 支付股权转让费会计科目
  • 购入固定资产一次性扣除
  • 非居民税收征管方式包括
  • 职工食堂支出明细表
  • 报销职工住院费多久到账
  • 个税专项扣除是什么时候开始实行
  • 破产清算收到的实收资本是破产资产吗
  • 现金账记错了该如何改正
  • 合伙企业转让股权需要其他股东同意吗
  • 收款收据写着投诉有效吗
  • 银行本票支付货款,余额退回
  • 自己做的房子可以办房产证吗
  • 政府扶持资金是什么意思
  • 企业合并以外
  • 流转税通俗举例
  • 非汉语是什么意思
  • 股票期权所得税率
  • 员工离职赔偿计入什么科目
  • 商品流通企业采购商品的进货费用金额较小的
  • 个体户租房交房怎么交税
  • 租金返还方式销售
  • 接受捐赠固定资产存货等有相关凭据的其成本按什么确定
  • 广告服务类企业有哪些
  • 虚开增值税简单例子
  • 支付银行托管费怎么入账
  • 应收账款余额包括预收账款
  • 事业单位财务预算管理制度
  • 普通发票多久之后还可以红冲
  • 事业单位政府预算
  • 外贸收汇怎么处理
  • 向股东借款作为股东借款
  • php判断密码长度
  • uname命令详解
  • python处理mysql如何拿到表头
  • /etc/rc.local添加内容
  • 机动车价外费用发票如何开具
  • 织梦cms要钱吗
  • 季度所得税收入多报,年度可以调整吗
  • 辞退补偿金的标准
  • 盘盈盘亏怎么看
  • 存货报废进项税额需要转出吗
  • 发票申领多久才可以批
  • 七天年化收益率2%
  • 超市购销和联营哪个好
  • 单位垫付职工个税如何记账
  • 企业的借款利息费用,扣除标准是?
  • 安置房买卖过户流程
  • 小规模纳税人企业所得税税率
  • 发票怎么跨月作废申请
  • 运费可以抵扣进项税额
  • 免税店为什么没有发票
  • 存货报废会计账务处理
  • 小规模季度没超过45万怎么纳税增值税
  • 申报表应纳税额和财务账金额不一致可以不改申报表吗
  • 编制合并财务报表的依据是纳入合并
  • 如何填写记账凭证视频
  • 会计报表分析的方法
  • sql实现行列转换
  • mysql深度解析
  • sqlserver1053怎么解决
  • 迅速修复系统漏洞的方法
  • 苹果怎么格式化彻底
  • SymSPort.exe - SymSPort是什么进程 有何作用
  • win10浏览器下载不了软件怎么回事
  • macbookpro怎么删除快捷方式
  • centos安装视频播放器
  • xp取消开机启动项
  • Android---60---Notification 通知栏的简单使用
  • 文件夹如何取名字
  • 用python分析csv文件
  • Node.js中的全局变量有哪些
  • javascript教程代码
  • js table插件
  • 广东省地税总局领导班子
  • 市中区税务局办税大厅上班时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设