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

  • 微信怎么更改实名认证(微信怎么更改实时到账)

    微信怎么更改实名认证(微信怎么更改实时到账)

  • 红米k40pro的后盖是什么材质的(红米k40pro后盖是用什么做的)

    红米k40pro的后盖是什么材质的(红米k40pro后盖是用什么做的)

  • 无线网络图标上有个叉(无线网络图标上有个感叹号怎么解决)

    无线网络图标上有个叉(无线网络图标上有个感叹号怎么解决)

  • 宽带上网的条件包括(宽带上网选择那种上网方式)

    宽带上网的条件包括(宽带上网选择那种上网方式)

  • 拼多多图片尺寸要求(拼多多图片尺寸多少怎么调)

    拼多多图片尺寸要求(拼多多图片尺寸多少怎么调)

  • 华为手机拉黑对方后能收到对方信息吗(华为手机拉黑对方电话号码还能收到短信吗?)

    华为手机拉黑对方后能收到对方信息吗(华为手机拉黑对方电话号码还能收到短信吗?)

  • 苹果x背面有一串英文(苹果x背面有一条黑线)

    苹果x背面有一串英文(苹果x背面有一条黑线)

  • 手机卡顿闪退是哪里出现了问题(手机卡顿闪退是中病毒了吗)

    手机卡顿闪退是哪里出现了问题(手机卡顿闪退是中病毒了吗)

  • 机械硬盘接sata几(机械硬盘接sata哪个接口)

    机械硬盘接sata几(机械硬盘接sata哪个接口)

  • 苹果6s绕过开机密码(苹果6s怎么绕开开机id)

    苹果6s绕过开机密码(苹果6s怎么绕开开机id)

  • 订单取消后钱什么时候返回来(订单取消后钱什么时候返回来京东)

    订单取消后钱什么时候返回来(订单取消后钱什么时候返回来京东)

  • 手机微信怎样重新登录(手机微信怎样重新实名认证)

    手机微信怎样重新登录(手机微信怎样重新实名认证)

  • 快手小店怎么找货源(快手小店怎么找官方客服介入)

    快手小店怎么找货源(快手小店怎么找官方客服介入)

  • 苹果xsmax有没有nfc功能(苹果xsmax现在多少钱)

    苹果xsmax有没有nfc功能(苹果xsmax现在多少钱)

  • xr有夜景模式吗(iphonexr有夜景模式)

    xr有夜景模式吗(iphonexr有夜景模式)

  • 水印相机可以录视频吗(水印相机可以录视频m)

    水印相机可以录视频吗(水印相机可以录视频m)

  • 微信别人发消息为什么没有显示(微信别人发消息不显示)

    微信别人发消息为什么没有显示(微信别人发消息不显示)

  • ios13如何设置暗黑模式(iphone13暗黑模式怎么设置)

    ios13如何设置暗黑模式(iphone13暗黑模式怎么设置)

  • 小爱音响mini恢复出厂设置(小米小爱音箱mini恢复出厂设置方法)

    小爱音响mini恢复出厂设置(小米小爱音箱mini恢复出厂设置方法)

  • cad测量面积快捷键(cad测量面积快捷键pl)

    cad测量面积快捷键(cad测量面积快捷键pl)

  • 2021最新win10激活密钥+神key推荐 附win数字永久激活工具+教程(最新版win10激活)

    2021最新win10激活密钥+神key推荐 附win数字永久激活工具+教程(最新版win10激活)

  • HTML+JS 实现 input 框回车事件(js设置input值)

    HTML+JS 实现 input 框回车事件(js设置input值)

  • 进项税额怎么抵税
  • 增值税专用发票有效期是多长时间
  • 停车费增值税税率
  • 无需外汇局审批的账户
  • 红字发票信息表编号在哪里看
  • 不开发票的入账怎么办?
  • 保险公司代收车船税在发票备注栏
  • 计提房产税计入哪个科目
  • 委托贷款的资金借出方是谁
  • 自建生产用机器设备领用本企业生产的产品
  • 股权出资登记管理办法已废止
  • 隔月发票红冲,交税怎么交
  • 去年房租忘记摊销怎么办
  • 哪些支出可计入成本
  • 企业给员工的异地安家费交个税吗?
  • 增值税征收比例和征收方式
  • 学校里的水电费是政府买单吗
  • 三方协议是先签先干活
  • 如何计算一般稳定球面腔的主要参量
  • 所得税调增调减项目
  • 总公司人员可以在分公司报销费用吗
  • 小规模补缴增值税怎么算
  • 支付工程款会计处理
  • windows7的笔记本有哪些
  • PHP:mb_ereg_replace_callback()的用法_mbstring函数
  • 应收账款可不可以作为质押合同的标的
  • wrme.exe是什么
  • 工程竣工决算会计账务处理
  • vue表单验证数字
  • php并发编程
  • 利用php实现一个数组
  • promise thenable
  • 网络安全网页设计作品构思
  • 图像风格迁移网站
  • thinkphp5微信公众号开发
  • 提取公益金会计怎么做账
  • 欠别人钱可以用车抵押吗
  • 织梦怎么安装
  • 即征即退相关证明材料
  • 工资单应该盖什么章
  • 废旧物资专用发票
  • sqlserver降级备份
  • 母公司和子公司是什么关系
  • 软件开发并销售产品
  • 制造费用和直接人工的关系
  • 上级补助收入科目
  • 营业税差额征税范围
  • 认缴的注册资金怎么做账
  • 工会筹备金该按什么计算
  • 预计负债可以获取利润吗
  • 人工费用和管理费用比例
  • 个体工商户怎样为员工缴纳社保
  • 未开票收入怎么报税
  • 计提工资时一定要发票吗
  • 发票丢失如何处理入账
  • sql server使用的是什么逻辑模型
  • 一个基于口令的用户身份认证基本过程是怎样的?
  • sql语句提取字符串中数字
  • win2003注册表空间不足
  • linux -al
  • linux cp 不是目录
  • linux连接windows的服务redis
  • win8打开蓝牙设置
  • 升级win10后悔了
  • WIN10系统优化精简工具
  • 深入解析windows第7版
  • 分区表 英语
  • linux ls-l命令详解
  • 使用NGUI时遇到物理引擎错误
  • 拥有一个属于自己的空间高中作文
  • shell脚本进程号
  • python3遍历
  • node.js 配置
  • 如何用python编写一个程序
  • android studio 开发语言
  • 江苏国税网上勾选平台
  • 契税和房产税是一回事吗
  • 深圳2021纳税
  • 遂宁市国家税务局
  • 公积金个人网上开户流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设