当前位置:   article > 正文

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

core.js


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到你的项目中。

npm i core-js
  • 1

2.项目中使用
方式一:
直接在入口文件import整个包 引入
缺点:假如只用到了一部分corejs的功能,整包引入导致编译后体积过大

import "core-js";
  • 1

方式二:
按需引入
比如项目中使用了promise语法,就使用import 'core-js/es/promise’引入promise模块

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

module.exports = {
    presets: [
      ["@babel/preset-env",{useBuiltIns:'usage',corejs:3}]
    ],
  };
  • 1
  • 2
  • 3
  • 4
  • 5

总结

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/624979
推荐阅读
相关标签
  

闽ICP备14008679号