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

  • 新浪微博seo优化的技巧(微博营销优化)

    新浪微博seo优化的技巧(微博营销优化)

  • 荣耀怎么设置地震报警(荣耀怎么设置地震预警强度)

    荣耀怎么设置地震报警(荣耀怎么设置地震预警强度)

  •  wps行距怎么设置在哪里(wps行距怎么设置20磅)

    wps行距怎么设置在哪里(wps行距怎么设置20磅)

  • 什么的出现使制造面向个人用户的微型计算机成为可能(什么的出现以及什么的发展)

    什么的出现使制造面向个人用户的微型计算机成为可能(什么的出现以及什么的发展)

  • 在powerpoint的页面设置中,能够设置(powerpoint页面设置在哪个选项卡)

    在powerpoint的页面设置中,能够设置(powerpoint页面设置在哪个选项卡)

  • 申请微信小程序要钱吗(个体户申请微信小程序)

    申请微信小程序要钱吗(个体户申请微信小程序)

  • 电话无法拨通,请将电话更改为本机号码是什么意思(电话无法拨通应该怎么办)

    电话无法拨通,请将电话更改为本机号码是什么意思(电话无法拨通应该怎么办)

  • miui智能服务是什么(miui11 智能服务)

    miui智能服务是什么(miui11 智能服务)

  • 没有nfc的手机能当门禁卡吗(没有nfc的手机能用云闪付吗)

    没有nfc的手机能当门禁卡吗(没有nfc的手机能用云闪付吗)

  • 12306二维码检票还需要身份证吗(12306二维码检票只有一个人的)

    12306二维码检票还需要身份证吗(12306二维码检票只有一个人的)

  • win10高级启动是什么(window10的高级启动)

    win10高级启动是什么(window10的高级启动)

  • cad图层颜色怎么改了没变化(cad图层颜色怎么改)

    cad图层颜色怎么改了没变化(cad图层颜色怎么改)

  • k30pro发布时间(k30pro发布价)

    k30pro发布时间(k30pro发布价)

  • 如何打开修订功能(如何打开修订功能键)

    如何打开修订功能(如何打开修订功能键)

  • 华为9手机可以用电信卡吗(华为9手机可以分屏吗)

    华为9手机可以用电信卡吗(华为9手机可以分屏吗)

  • 华为mate30有红外线功能吗(华为mate30有红外人脸吗)

    华为mate30有红外线功能吗(华为mate30有红外人脸吗)

  • word怎样设置下划线(word怎样设置下划线颜色)

    word怎样设置下划线(word怎样设置下划线颜色)

  • 抖音200粉丝能开播吗(抖音200个粉丝)

    抖音200粉丝能开播吗(抖音200个粉丝)

  • 预售怎么加入购物车(怎么参加预售)

    预售怎么加入购物车(怎么参加预售)

  • 微信怎么弄提示音(微信怎么弄提示收到信息)

    微信怎么弄提示音(微信怎么弄提示收到信息)

  • ps下载电脑版怎么下载(ps下载电脑版怎么下载多少钱)

    ps下载电脑版怎么下载(ps下载电脑版怎么下载多少钱)

  • 轻颜相机贴纸在哪(轻颜相机贴纸在哪里找到)

    轻颜相机贴纸在哪(轻颜相机贴纸在哪里找到)

  • 红米k20pro有光学防抖吗(红米k20pro有光学变焦吗)

    红米k20pro有光学防抖吗(红米k20pro有光学变焦吗)

  • 大王卡3g网络怎么回事(大王卡3gwap)

    大王卡3g网络怎么回事(大王卡3gwap)

  • 文本模式命令提示符版安装CentOS 6.5的图文方法(文本模式是什么意思?)

    文本模式命令提示符版安装CentOS 6.5的图文方法(文本模式是什么意思?)

  • DETR源码笔记(一)(dex源码提取)

    DETR源码笔记(一)(dex源码提取)

  • 帝国cms收费吗(帝国cms真的很好用)

    帝国cms收费吗(帝国cms真的很好用)

  • 启用新账簿时,应填写
  • 国家税务总局操作指引
  • 视同销售发放福利的会计分录
  • 出口退税是先交税后退税吗
  • 发票验旧期限
  • 小规模纳税人不开票需要纳税吗
  • 个税系统添加不了新的单位
  • 公司开劳务发票几个点
  • 固定资产折旧年限
  • 实际报销人是什么意思
  • 应交税金明细账余额怎么算
  • 材料采购成本差异属于什么科目
  • 公司亏损没有收入怎么办
  • 增值税发票委托公司开具
  • 办理营业执照需要钱吗
  • 固定资产预计净残值怎么做账
  • 其他服务业经营范围包括哪些
  • 酒类消费税征收环节归纳
  • 未分配利润转增股本 个人所得税
  • 高危行业企业探索实行什么制度
  • 哪些政府补助可以做收入
  • 税法三流合一是哪一项法律依据
  • 企业间拆借应收利息记哪个科目?
  • 基金的业绩是什么
  • 借贷记账法的记账规则是
  • 新办企业税务服务
  • 客户罚款记哪个科目
  • 发票跨年作废很麻烦吗
  • PHP:mcrypt_create_iv()的用法_Mcrypt函数
  • 房地产会计核算地上地下成本分摊
  • 接受专利投资会亏本吗
  • 企业注销清算需要交什么税
  • 免费镜像翻转软件
  • 企业期末结转本期实现的各项收入
  • 股权转让完税证明要多少时间
  • 金税盘锁死状态
  • php判断包含指定内容
  • 帝国cms怎么用
  • 预付的购货款计入什么科目
  • java中同步有两种方法
  • PostgreSQL教程(三):表的继承和分区表详解
  • 政府补助确认递延所得税负债
  • 公司用卫生纸是干什么的
  • 累计折旧计提会计分录
  • 长期股权投资在现金流量表哪里体现
  • 个人怎么缴纳五险一金
  • 报价中含税和不含税比例
  • 可转债公允价值变动计入
  • 装饰公司购买的安装服务怎么入账
  • 饭店的会计做账怎么做
  • 根据企业会计准则第4号固定资产,企业可选用的折旧方法
  • mysql数据库数据备份
  • centos6.9关闭防火墙命令
  • win7系统u口怎么禁用
  • ie11 ua
  • mac怎么创建apple id
  • easybcd修复ubuntu
  • wp升级
  • 使用移动硬盘快速启动
  • linux下使用lftp的小结(远程服务器备份)
  • ssh进入
  • win7语言栏不见了 各种方法都试过了
  • linux几种安装方式
  • windowsxp oobe
  • pavmail.exe - pavmail进程是什么文件 有什么用
  • windows中的hosts文件
  • [置顶]马粥街残酷史
  • unix中创建新文件
  • pull order
  • unity shader可视化编辑
  • unity优化技巧
  • 自己搭配电脑
  • jquery的实现原理
  • jquery的哪个方法可以绑定mouseover
  • 装饰装修公司需要什么
  • 高速发票查询平台官网
  • 北京市国家税务局网站官网
  • 党建引领结对共建生态
  • 电子保险怎么查询车船税
  • 国家税务总局中山市税务局港口税务分局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设