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

  • 网址站优化细节的分析(网站优化入门)

    网址站优化细节的分析(网站优化入门)

  • iqoo的语音助手叫什么名字(iQOO的语音助手叫什么名字)

    iqoo的语音助手叫什么名字(iQOO的语音助手叫什么名字)

  • 华为nova9pro是什么系统(华为nova9Pro是什么型号)

    华为nova9pro是什么系统(华为nova9Pro是什么型号)

  • vivox27滚动壁纸怎么设置(vivox27手机壁纸怎么设置不滚动模式)

    vivox27滚动壁纸怎么设置(vivox27手机壁纸怎么设置不滚动模式)

  • mooc期末考试可以切屏吗(mooc期末考试可以补考吗)

    mooc期末考试可以切屏吗(mooc期末考试可以补考吗)

  • 苹果11怎么开空调(苹果11怎么开空调教程视频)

    苹果11怎么开空调(苹果11怎么开空调教程视频)

  • 电话闪退怎么回事(电话界面闪退)

    电话闪退怎么回事(电话界面闪退)

  • qq强制会话是啥意思(qq强制会话app)

    qq强制会话是啥意思(qq强制会话app)

  • 打印机主机名指的是什么(打印机主机名称是什么)

    打印机主机名指的是什么(打印机主机名称是什么)

  • 苹果win10截图快捷键(苹果win10怎么截图)

    苹果win10截图快捷键(苹果win10怎么截图)

  • 开启卡2流量卡1就无法使用了(卡2流量卡1能用吗)

    开启卡2流量卡1就无法使用了(卡2流量卡1能用吗)

  • 苹果无线耳机电量怎么看不到(苹果无线耳机电量在哪看)

    苹果无线耳机电量怎么看不到(苹果无线耳机电量在哪看)

  • ip协议组包括什么协议(ip协议包含)

    ip协议组包括什么协议(ip协议包含)

  • 5g流量卡4g手机能用吗(5g手机用4g流量卡)

    5g流量卡4g手机能用吗(5g手机用4g流量卡)

  • gtx1050是什么显卡

    gtx1050是什么显卡

  • qq解除屏蔽后能接收到之前消息吗(qq解除屏蔽后能看到屏蔽期间的消息吗)

    qq解除屏蔽后能接收到之前消息吗(qq解除屏蔽后能看到屏蔽期间的消息吗)

  • 序列号fd开头的是什么(序列号f.开头)

    序列号fd开头的是什么(序列号f.开头)

  • 如何跨列居中(跨列居中excel)

    如何跨列居中(跨列居中excel)

  • xr 8p尺寸对比(8p和xr外形尺寸)

    xr 8p尺寸对比(8p和xr外形尺寸)

  • 如何防止别人偷看我的手机(如何防止别人偷东西)

    如何防止别人偷看我的手机(如何防止别人偷东西)

  • 苹果7背光排线断了(苹果7背光排线能换吗)

    苹果7背光排线断了(苹果7背光排线能换吗)

  • qq临时会话红色感叹号(qq临时会话红色感叹号怎么恢复)

    qq临时会话红色感叹号(qq临时会话红色感叹号怎么恢复)

  • 天翼看家支持5部终端么(天翼看家支持5G吗)

    天翼看家支持5部终端么(天翼看家支持5G吗)

  • 手机hd要不要关闭

    手机hd要不要关闭

  • 文件夹如何排序(金山词霸文件夹如何排序)

    文件夹如何排序(金山词霸文件夹如何排序)

  • 如何制作ps视频(怎么制作ps视频)

    如何制作ps视频(怎么制作ps视频)

  • Web自动化测试怎么做?Web自动化测试的详细流程和步骤(web 自动化测试)

    Web自动化测试怎么做?Web自动化测试的详细流程和步骤(web 自动化测试)

  • 小规模超过30万计算
  • 进项税额转出期末有余额吗
  • 简易计税是否要申报个税
  • 2019年一季度季报怎样填写
  • 核定征收企业有哪些
  • 利用废旧物资生产设备
  • 长投损失了如何处理
  • 公司按最低标准缴纳社保
  • 未确认融资费用借贷方向
  • 发票抬头写错了还能报销吗
  • 建筑公司不需要预缴增值税的有
  • 企业员工用自己手机发送工作
  • 季度销售额不超过30万,城建税减免
  • 财务报表提供的信息仅对外部的投资者和债权人有用
  • 工会经费具体用途是什么
  • 资金筹集业务核算实训心得体会
  • 我的初级备考经验--相信自己
  • 苹果mac有hdmi
  • 品牌转让怎么写
  • 修改php.ini
  • 红蘑菇是什么松树伞吗
  • linux怎么设置读写权限
  • 股权转让的条件和方式
  • 存入保证金账户分录怎么写
  • php .htaccess
  • 高新技术企业补助需要交所得税吗
  • 对外投资概述
  • 小规模纳税人的个人所得税怎么算
  • 无效借款合同自被确认为无效之日起无效
  • 职工教育经费会计账务处理
  • 页面白屏可能原因前端
  • 营改增几个阶段
  • js解耦
  • mybitas分页
  • 车辆保险费用的申请模板
  • typescriptlang
  • framework3.5怎么打开
  • uni.getSystemInfo(OBJECT)
  • 企业财政拨款所得免税吗
  • python中字符串转数字函数
  • 开源 okr
  • 在ubuntu中安装win10
  • 营业外支出增加记借方还是贷方
  • 控股子公司注销公告是利空吗
  • sqlserver修改数据库密码
  • 所得税申报表营业成本包括哪些
  • 附加税减半征收实例账务处理
  • 个体工商户定期定额怎么报税
  • 公司人身意外保险多少钱
  • 长期股权投资的账务处理
  • 如果收到现金做账了还叫坐支
  • 商业承兑汇票如何承兑?
  • 将外购商品作为非货币
  • 变更印鉴单位公函格式
  • 验资账户需要对账吗
  • 信用证保证金到期怎么处理
  • 会计准则规定了什么
  • 企业凭证处理流程图
  • 哪些行业可以开收购发票
  • 银行业现金流量表
  • 利息专用发票可以抵扣吗
  • 明年发票可以入到今年有什么惩罚
  • 超市库存明细表
  • sqlserver数据库怎么导出
  • windows10安装教程u盘安装
  • http500内部错误
  • win2003 IIS6.0+PHP+MySQL的安?配置
  • linux怎么禁用命令
  • 服务win10
  • mac系统怎么设置默认应用
  • 凭据管理器 win10
  • js函数命名
  • js实例教程
  • Scrapy框架可以用于数据挖掘、监测和自动化测试
  • nodejs爬虫技术
  • unity shader可视化编辑
  • 医疗费发票查询
  • 定期定额发票使用流程
  • 建设工程勘察设计单位可跨部门跨地区承揽勘察设计业务
  • 表彰税务工作者们的活动策划
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设