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

  • 如何让自己的网站在网络推广有效的转化率(如何让自己的网站搜关键词)

    如何让自己的网站在网络推广有效的转化率(如何让自己的网站搜关键词)

  • 手机wifi正常平板不能上网(手机无线连接正常但是无法上网)

    手机wifi正常平板不能上网(手机无线连接正常但是无法上网)

  • airpods3触摸功能怎么用(airpods3触碰)

    airpods3触摸功能怎么用(airpods3触碰)

  • oppo手机声音太大怎么调整(OPPO手机声音太小)

    oppo手机声音太大怎么调整(OPPO手机声音太小)

  • 电脑保护屏幕怎么设置(电脑保护屏幕怎么退出来)

    电脑保护屏幕怎么设置(电脑保护屏幕怎么退出来)

  • 小米color可以听歌吗(小米color怎么听歌)

    小米color可以听歌吗(小米color怎么听歌)

  • 电费卡怎么插(电费卡插哪里)

    电费卡怎么插(电费卡插哪里)

  • 淘宝店铺不存在了售后找谁(淘宝店铺不存在可以直接申请退款吗)

    淘宝店铺不存在了售后找谁(淘宝店铺不存在可以直接申请退款吗)

  • soul群聊房间怎么没有了(soul聊天房间)

    soul群聊房间怎么没有了(soul聊天房间)

  • qq邮箱黑名单在哪查看(qq邮箱黑名单在哪里设置)

    qq邮箱黑名单在哪查看(qq邮箱黑名单在哪里设置)

  • idc概念是什么意思(idc概念股是什么意思)

    idc概念是什么意思(idc概念股是什么意思)

  • vivo手机摔了一下开不了机怎么办(vivo手机摔了一下子黑屏了怎么办)

    vivo手机摔了一下开不了机怎么办(vivo手机摔了一下子黑屏了怎么办)

  • 苹果蜂窝网络有什么用(苹果蜂窝网络有必要开吗)

    苹果蜂窝网络有什么用(苹果蜂窝网络有必要开吗)

  • 暂时无人接听是什么意思 (暂时无人接听是啥意思)

    暂时无人接听是什么意思 (暂时无人接听是啥意思)

  • oppoa11手机呼吸灯在哪(oppo手机呼吸灯一直闪烁怎么关闭)

    oppoa11手机呼吸灯在哪(oppo手机呼吸灯一直闪烁怎么关闭)

  • 闪送一次能接几单(闪送一次能接几单货)

    闪送一次能接几单(闪送一次能接几单货)

  • 苹果2代耳机怎么下一曲(苹果2代耳机怎么看真假)

    苹果2代耳机怎么下一曲(苹果2代耳机怎么看真假)

  • 小米智能出行如何使用(小米智能出行怎么使用)

    小米智能出行如何使用(小米智能出行怎么使用)

  • 仅自己可见怎样去除(说说 仅自己可见)

    仅自己可见怎样去除(说说 仅自己可见)

  • 为什么ps放大后很模糊(为什么ps放大后是黑色的)

    为什么ps放大后很模糊(为什么ps放大后是黑色的)

  • 微信收款码怎么停用(微信收款码怎么关闭收款功能)

    微信收款码怎么停用(微信收款码怎么关闭收款功能)

  • 小米手机微信扫一扫扫不出来(小米手机微信扫码黑屏怎么回事)

    小米手机微信扫一扫扫不出来(小米手机微信扫码黑屏怎么回事)

  • Tomcat安装使用与部署Web项目的三种方法(tomcat的安装配置)

    Tomcat安装使用与部署Web项目的三种方法(tomcat的安装配置)

  • 企业税前扣除凭证包括增值税发票吗
  • 个体户查账征收怎么交税?
  • 公司全部股权转让流程
  • 废机油处理多少钱一吨
  • 上年多计提增值税,今年如何调整
  • 水利建设基金的计税依据
  • 归属于母公司的净资产
  • 新税法下广告费和业务宣传费的扣除是怎样?
  • 固定资产弃置费用计入什么科目
  • 公司报销费用发票怎么开
  • 企业接收捐赠计入什么科目
  • 财产性收入是非劳动性收入吗
  • 商贸企业增值税优惠政策
  • 专用发票红冲后可以退税吗?
  • 前三季度盈利第四季度亏损 所得税记账
  • 普票名称错了税号没错
  • 没有缴纳社保怎么开证明
  • 个人所得税返还奖励财务人员做账
  • 不是办税员可以去税局办事吗
  • 增值税发票校验码是什么意思
  • 哪些开普通发票
  • 外地预缴个人所得税如何入账及申报
  • 股东向公司借款需要交税吗
  • 交叉持股的合并财务报表
  • 企业员工差旅平台排行
  • 外贸企业出口收入确定
  • 短期借款有没有上年结转
  • 在王者荣耀里怎么删除好友
  • 无发票 入账
  • 银行与银行之间转账会计摘要
  • 以前年度损益调整结转到哪里
  • PHP:mb_ereg_match()的用法_mbstring函数
  • Windows11如何使用管理员账号登录
  • 个人所得税手续费返还
  • hpp是什么文件
  • 应付股利的会计科目
  • php socket select
  • 上年度成本费用包括哪些
  • 远程访问群晖nas
  • 账本过次页的视频
  • 经营租入固定资产
  • 软考软件设计师考试时间
  • date=date
  • 利润分配反映什么
  • 其他资本公积核算科目
  • 车辆购置税属于地方税吗
  • 个人所得税其他扣除300一个月
  • 工程项目成本管理实论
  • 全年一次性奖金税率表2023最新
  • mysql和mongo的区别
  • 企业出租专利技术收取的租金不得确认为收入对吗
  • 普通发票税额没有打印全可以用么
  • 预付账款未发货会计分录
  • 出口退税是先交税后退税吗
  • 跨境电商财务如何报税
  • 长期待摊费用科目怎么使用
  • 企业进项构成比例
  • 原始凭证按什么分
  • 银行存款利息的结算方式
  • 财务报表是否合法公允
  • mysql常见优化手段
  • mysqlpid文件没有
  • mysql 5.7.28安装
  • 索尼vaio笔记本无法开机
  • win7家庭版开启administrator
  • grub修复引导windows10
  • linux的tar命令用法
  • windows8怎么新建word文档
  • windows10如何多选文件
  • 批处理命令在哪个菜单中
  • 背包设备
  • nodejs 性能测试
  • android 生成图片
  • [置顶]马粥街残酷史
  • windows、linux
  • jquery filedownload
  • JavaScript事件类型中焦点、鼠标和滚轮事件详解
  • 高速公路发票在哪里开
  • 涉嫌虚开增值税专用发票罪
  • 关于企业所得税的说法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设