Webpack5 core-js和babel-loader区别和用法

文章目录


core-js是什么,有什么用?

core-js是一个流行的JavaScript库,它提供了对新的JavaScript特性、API和方法的兼容性支持。它通过模拟缺失的功能,并提供polyfill来使这些功能可以在旧版浏览器中正常运行

polyfill翻译过来叫做垫片/补丁。就是用社区上提供的一段代码,让我们在不兼容某些新特性的浏览器上,使用该新特性。

为什么使用了babel-loader对js进行兼容性配置还需要core-js?

在Webpack 5中,使用babel-loader对JavaScript进行兼容性配置可以将新版本的JavaScript语法转换为低版本的语法,以便在旧版浏览器中正常运行。然而,babel-loader只会处理语法转换,而不会处理新增的API或全局对象。对于一些新的API(如Promise、Array.from等)或全局对象(如Symbol、Map等),我们仍然需要使用core-js来提供兼容性支持。

core-js的具体用法

1.安装core-js:通过npm或yarn安装core-js到你的项目中。

javascript 复制代码
npm i core-js

2.项目中使用

方式一:

直接在入口文件import整个包 引入

缺点:假如只用到了一部分corejs的功能,整包引入导致编译后体积过大

javascript 复制代码
import "core-js";

方式二:

按需引入

比如项目中使用了promise语法,就使用import 'core-js/es/promise'引入promise模块

方式三:

自动按需引入(最推荐),配置babel.config.js, 这样就可以根据项目中用到的语法进行依赖

javascript 复制代码
module.exports = {
    presets: [
      ["@babel/preset-env",{useBuiltIns:'usage',corejs:3}]
    ],
  };

总结

通过使用babel-loader进行语法转换只能解决部分兼容性问题,而对于新增的API和全局对象,我们需要借助core-js来提供兼容性支持。核心思想是使用polyfill模拟缺失的功能,从而使JavaScript应用程序能够在各种浏览器中工作。通过合理配置Webpack和使用core-js,我们可以大大提升JavaScript应用程序的跨浏览器支持,为用户提供更好的体验

相关推荐
小小小小宇4 分钟前
前端按需引入总结
前端
小小小小宇21 分钟前
React 的 DOM diff笔记
前端
小小小小宇28 分钟前
react和vue DOM diff 简单对比
前端
我在北京coding30 分钟前
6套bootstrap后台管理界面源码
前端·bootstrap·html
Carlos_sam34 分钟前
Opnelayers:封装Popup
前端·javascript
MessiGo1 小时前
Javascript 编程基础(5)面向对象 | 5.1、构造函数实例化对象
开发语言·javascript·原型模式
前端小白从0开始1 小时前
Vue3项目实现WPS文件预览和内容回填功能
前端·javascript·vue.js·html5·wps·文档回填·文档在线预览
JohnYan2 小时前
Bun技术评估 - 03 HTTP Server
javascript·后端·bun
开开心心就好2 小时前
高效Excel合并拆分软件
开发语言·javascript·c#·ocr·排序算法·excel·最小二乘法