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

  • 蘑菇街网站推荐(像蘑菇街一样的网站)(蘑菇街的网址是多少)

    蘑菇街网站推荐(像蘑菇街一样的网站)(蘑菇街的网址是多少)

  • 剪辑怎么加快视频速度(视频剪辑怎么加快)

    剪辑怎么加快视频速度(视频剪辑怎么加快)

  • 拉黑再删除永久加不上怎么办(拉黑再删除永久加不上怎么设置)

    拉黑再删除永久加不上怎么办(拉黑再删除永久加不上怎么设置)

  • oppo便签突然没了(oppoa11便签桌面上没有)

    oppo便签突然没了(oppoa11便签桌面上没有)

  • 通常所说的裸机是指计算机仅有什么(通常所说裸机包括)

    通常所说的裸机是指计算机仅有什么(通常所说裸机包括)

  • 开通抖音直播要交钱吗(开通抖音直播要具备些什么条件)

    开通抖音直播要交钱吗(开通抖音直播要具备些什么条件)

  • 腾讯会议提前进入过别人会不会看到(腾讯会议提前进入会议有人知道吗)

    腾讯会议提前进入过别人会不会看到(腾讯会议提前进入会议有人知道吗)

  • 手机突然不能全屏了(手机突然不能全屏了OPPO)

    手机突然不能全屏了(手机突然不能全屏了OPPO)

  • 如何解决滴滴定位不准(滴滴定位模式异常怎么调整)

    如何解决滴滴定位不准(滴滴定位模式异常怎么调整)

  • 防火墙5个基本功能(防火墙5个基本组成)

    防火墙5个基本功能(防火墙5个基本组成)

  • 平板死机怎么重启(平板死机重启不了)

    平板死机怎么重启(平板死机重启不了)

  • 华为mate30支持ufs3.0吗(华为Mate30支持快充吗)

    华为mate30支持ufs3.0吗(华为Mate30支持快充吗)

  • 苹果11自动重启是怎么回事(苹果11自动重启显示CPU供电不足)

    苹果11自动重启是怎么回事(苹果11自动重启显示CPU供电不足)

  • j1900相当于什么cpu(j1900相当于什么档次)

    j1900相当于什么cpu(j1900相当于什么档次)

  • 手机的歌怎么传到mp3(手机的歌怎么传到另一个手机)

    手机的歌怎么传到mp3(手机的歌怎么传到另一个手机)

  • 滴滴快车怎么打往返车(滴滴快车怎么打开)

    滴滴快车怎么打往返车(滴滴快车怎么打开)

  • 小米手环4怎么设置公交卡(小米手环4怎么调时间和日期)

    小米手环4怎么设置公交卡(小米手环4怎么调时间和日期)

  • 苹果xs有双网通版本吗

    苹果xs有双网通版本吗

  • reno2上市时间(reno2什么时候上市)

    reno2上市时间(reno2什么时候上市)

  • 手机屏幕字幕怎么设置(手机屏幕字幕怎么弄)

    手机屏幕字幕怎么设置(手机屏幕字幕怎么弄)

  • ipad如何设置儿童使用时间(如何给ipad设置儿童锁)

    ipad如何设置儿童使用时间(如何给ipad设置儿童锁)

  • 靓仔语塞是什么梗(女的对我说靓仔语塞是啥意思)

    靓仔语塞是什么梗(女的对我说靓仔语塞是啥意思)

  • qq钱包原始密码是多少(qq钱包的密码怎么改密码)

    qq钱包原始密码是多少(qq钱包的密码怎么改密码)

  • 爆改YOLOV7的detect.py制作成API接口供其他python程序调用(超低延时)(yolov5怎么改进)

    爆改YOLOV7的detect.py制作成API接口供其他python程序调用(超低延时)(yolov5怎么改进)

  • 公司买房子可以贷款多少
  • 税务行政复议是税务行政复议机关的裁决活动
  • 小微企业免税销售额是按1%还是3%
  • 单位出租不动产印花税
  • 资金收益率计应收账款吗
  • 分公司可以独立开银行账户吗
  • 建筑行业分包款要分项目扣除吗
  • 支付投资人的投资收益账务处理
  • 小规模纳税人未开票收入填在哪里
  • 开票交税当月不确认收入如何做账?
  • 纳税评估怎么办
  • 报关单不存在
  • 现金存款账户
  • 建筑企业之前的工作内容
  • 增值税普票需要填写什么内容
  • 广告公司可以开服务费吗
  • 年终奖怎么缴纳个税
  • 境外单位或者个人
  • 银行开户存入的钱怎么取
  • 票据再质押
  • 固定资产计提折旧的会计科目
  • 固定资产处理收入计入什么科目
  • 港杂费是由谁收取
  • 税务机构
  • 发票认证平台登陆不了,IE不成功
  • 计划成本是什么科目
  • 本月发生的费用,下月取得发票,怎么做账
  • php中session的作用
  • php mysql_real_escape_string函数用法与实例教程
  • 小米无线路由器internet黄灯
  • 向银行借入长期借款50万元
  • 进度条js代码
  • 计提增值税可以无付凭证吗
  • wordpress自定义函数
  • php封装数据库操作
  • php忘记密码功能
  • php环境搭建教程
  • opencv训练模型教程
  • vue开发环境和生产环境域名配置
  • 煤炭贸易公司的业务流程
  • css 3有哪些新特性
  • 销售边角料的会计分录
  • mongodb import
  • 控股子公司注销公告是利空吗
  • 关于翡翠手镯知识
  • 暂估入库跨年账务危险
  • 增值税直接计算法间接计算法举例
  • 息税前利润的计算公式EBIT
  • 收到预付货款用什么凭证
  • 打印银行电子回单有断号
  • 委外加工物资管理制度
  • 跨年的应收账款多做了怎么做账
  • 将外购商品作为非货币
  • 教育局给幼儿园的补贴
  • 差旅费记入哪个费用
  • 设置资产处置损益的依据
  • 分公司给总公司分红怎么入账
  • 联想s5s531笔记本M2
  • 添加网络打印机找不到设备
  • winhlp32.exe - winhlp32是什么进程
  • win8系统怎么设置密码
  • 惠普笔记本重装系统后没有无线连接
  • win8设置无线网络
  • win7电脑操作日志怎么查看
  • linux ssh key登录
  • 原生java web
  • nodejs函数返回值
  • linux安装jdk和tomcat
  • javascript基础编程
  • 也论主板的扩展性
  • node服务器部署
  • android内存机制
  • android自定义ui
  • 谈谈我对秦始皇的看法
  • 如何查询车辆购置税是否缴纳
  • 企业投资项目备案表模板
  • 政府对国税局的支持
  • 郑州地方税务局网站官网
  • 江西国家税务局电子税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设