iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Vue中如何使用babel-polyfill兼容低版本浏览器
  • 251
分享到

Vue中如何使用babel-polyfill兼容低版本浏览器

2023-07-05 04:07:02 251人浏览 安东尼
摘要

今天小编给大家分享一下Vue中如何使用babel-polyfill兼容低版本浏览器的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下

今天小编给大家分享一下Vue中如何使用babel-polyfill兼容低版本浏览器的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

    注意:本文主要介绍的 vue-cli 版本:3.x, 4.x;
    最近在项目中使用 webpack 打包后升级,用户反馈使用浏览器(chrome 45)访问白屏。经过排查发现:由于 chrome 45 无法兼容 es6 语法导致的,因此需要将项目中的 ES6 语法转 ES5 语法。

    Vue中如何使用babel-polyfill兼容低版本浏览器

    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']}

    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 说明

    Vue中如何使用babel-polyfill兼容低版本浏览器

    补充说明

    • 如安装配置 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)。

    以上就是“Vue中如何使用babel-polyfill兼容低版本浏览器”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。

    --结束END--

    本文标题: Vue中如何使用babel-polyfill兼容低版本浏览器

    本文链接: https://www.lsjlt.com/news/349472.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Vue中如何使用babel-polyfill兼容低版本浏览器
      今天小编给大家分享一下Vue中如何使用babel-polyfill兼容低版本浏览器的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
      99+
      2023-07-05
    • vue对于低版本浏览器兼容问题的解决思路
      目录准备工具库进阶使用问题例子解决思路语法不支持具体哪个使用了哪个库不支持兼容语法总结准备 由于采用了vite3而不是vue-cli,所以以前的很多兼容方式都不能做。接下来就看一下v...
      99+
      2023-02-10
      vue如何兼容低版本浏览器 vue浏览器版本支持 vue浏览器兼容性问题有哪些
    • 如何判断浏览器版本的语句且可兼容多个浏览器
      本篇内容主要讲解“如何判断浏览器版本的语句且可兼容多个浏览器”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何判断浏览器版本的语句且可兼容多个浏览器”吧!<!--[if lte IE 6]...
      99+
      2023-06-08
    • HTML5中Placeholder解决新标签低版本浏览器下不兼容的示例分析
      HTML5中Placeholder解决新标签低版本浏览器下不兼容的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。placehold...
      99+
      2022-10-19
    • 如何用条件注释判断浏览器版本解决页面兼容问题
      这篇文章主要介绍“如何用条件注释判断浏览器版本解决页面兼容问题”,在日常操作中,相信很多人在如何用条件注释判断浏览器版本解决页面兼容问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
      99+
      2022-10-19
    • 如何使用条件注释判断IE浏览器版本适用于IE5.0及以上版本
      这篇文章将为大家详细讲解有关如何使用条件注释判断IE浏览器版本适用于IE5.0及以上版本,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。IE条件注释是一种特殊...
      99+
      2022-10-19
    • Linux如何使用文本浏览器lynx并显示中文
      小编给大家分享一下Linux如何使用文本浏览器lynx并显示中文,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!使用Fedora,当然需要玩一些酷的东东,lynx是在文本环境下不错的网页浏览工具,在网速不好的时候使用lynx...
      99+
      2023-06-12
    • 了解如何在ASP容器中实时使用Git进行版本控制
      在现代软件开发中,版本控制是必不可少的工具。Git是一款非常流行的版本控制系统,可以帮助开发人员跟踪代码变更、管理代码版本以及协同开发。在ASP容器中使用Git可以使开发人员更加高效地管理代码,本文将详细介绍如何在ASP容器中实时使用Gi...
      99+
      2023-08-28
      容器 实时 git
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作