搜索

查看: 3217|回复: 11

[JavaScript] Vue中 引入使用 babel-polyfill 兼容低版本浏览器的方法

[复制链接]
发表于 2023-5-4 11:50:32 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:50:32 3217 11 看全部
目录
  • 1. 兼容低版本浏览器方法
  • 1.1 安装 babel-polyfill
  • 1.2 引入
  • 1.3(新增)在 babel.config.js 中配置
  • 1.4 在 vue.config.js (新增)配置 transpileDependencies
  • 2. vue-cli 2.x 中配置 babel 转换
  • 拓展:关于 Babel 简介注意:本文主要介绍的 vue-cli 版本:3.x, 4.x;
    最近在项目中使用 webpack 打包后升级,用户反馈使用浏览器(chrome 45)访问白屏。经过排查发现:由于 chrome 45 无法兼容 ES6 语法导致的,因此需要将项目中的 ES6 语法转 ES5 语法。

    2023022014373037.png

    Vue中 引入使用 babel-polyfill 兼容低版本浏览器的方法112 作者:Editor 帖子ID:2756 引入,使用,兼容,版本,浏览知鸟论坛_zn60.com


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

    2023022014373038.png

    Vue中 引入使用 babel-polyfill 兼容低版本浏览器的方法1423 作者:Editor 帖子ID:2756 引入,使用,兼容,版本,浏览知鸟论坛_zn60.com


    补充说明
  • 如安装配置 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);
  • 发表于 2023-6-28 17:50:44 | 显示全部楼层
    墙和鸡蛋 2023-6-28 17:50:44 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    发表于 2023-6-29 01:34:03 | 显示全部楼层
    塞翁364 2023-6-29 01:34:03 看全部
    这东西我收了!谢谢楼主!知鸟论坛真好!
    发表于 2023-6-29 05:44:56 | 显示全部楼层
    十二音阶囤 2023-6-29 05:44:56 看全部
    感谢楼主的无私分享!要想知鸟论坛好 就靠你我他
    发表于 2023-6-29 13:45:21 | 显示全部楼层
    素色流年783 2023-6-29 13:45:21 看全部
    论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛。
    发表于 2023-6-29 21:31:12 | 显示全部楼层
    123456809 2023-6-29 21:31:12 看全部
    楼主太厉害了!楼主,I*老*虎*U!我觉得知鸟论坛真是个好地方!
    发表于 2023-6-29 21:31:55 | 显示全部楼层
    123456833 2023-6-29 21:31:55 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    发表于 2023-6-30 09:37:15 | 显示全部楼层
    麻辣鸡翅 2023-6-30 09:37:15 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    发表于 2023-6-30 10:12:25 | 显示全部楼层
    计划你大爷计j 2023-6-30 10:12:25 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    发表于 2023-6-30 21:07:45 | 显示全部楼层
    Gordon520 2023-6-30 21:07:45 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    • 您可能感兴趣
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| 小黑屋| 知鸟论坛 |网站地图
    本站资源来自互联网用户收集发布,如有侵权请邮件联系处理。 联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表