当前位置: 首页 > 编程笔记 >

使用webpack将ES6转化ES5的实现方法

濮泳
2023-03-14
本文向大家介绍使用webpack将ES6转化ES5的实现方法,包括了使用webpack将ES6转化ES5的实现方法的使用技巧和注意事项,需要的朋友参考一下

babel使用

打开babel官网,按教程安装babel

安装

npm install --save-dev babel-loader @babel/core @babel/preset-env

配置rules

module: {
 rules: [
  { test: /\.js$/, exclude: /node_modules/, loader: "babel-loader" }
 ]
}

生成 .babelrc文件

{
 "presets": ["@babel/preset-env"]
}

此时webpack已经能正确的将高版本的js语法转为低版本的语法,但是对于新增的api并不会转化,如promise。这时我们就需要其他的插件

使用polyfill插件,对于babel=>7.4.0该方法弃用

安装

npm install --save @babel/polyfill

修改 .babelrc

{
 "presets": [
  [
   "@babel/preset-env",
   {
     "useBuiltIns":"usage" // 只转化使用了的API
   }
  ]
 ]
}

使用 在需要转换的文件里引入polyfill

import "@babel/polyfill";

@babel/polyfill 和 @babel/preset-env 的关系

@babel/preset-env 中与 @babel/polyfill 的相关参数有 targets 和 useBuiltIns 两个

targets: 支持的目标浏览器的列表

useBuiltIns: 参数有 “entry”、”usage”、false 三个值。默认值是false,此参数决定了babel打包时如何处理@babel/polyfilll 语句。

“entry”: 会将文件中 import‘@babel/polyfilll'语句 结合 targets ,转换为一系列引入语句,去掉目标浏览器已支持的polyfilll 模块,不管代码里有没有用到,只要目标浏览器不支持都会引入对应的polyfilll 模块。

“usage”: 不需要手动在代码里写import‘@babel/polyfilll',打包时会自动根据实际代码的使用情况,结合 targets 引入代码里实际用到 部分 polyfilll 模块

false: 对 import‘@babel/polyfilll'不作任何处理,也不会自动引入 polyfilll 模块

使用plugin-transform-runtime

安装

npm install --save-dev @babel/plugin-transform-runtime

修改 .babelrc

{
"presets": [
  [
   "@babel/preset-env"
  ]
 ],
 "plugins": [
  [
   "@babel/plugin-transform-runtime",
   {
    "absoluteRuntime": false,
    "corejs": 3,
    "helpers": true,
    "regenerator": true,
    "useESModules": false
   }
  ]
 ]
}

注意上面corejs设置项,不同的值需要不同的依赖包

corejs的值 需要安装的依赖包
false npm install --save @babel/runtim
2 npm install --save @babel/runtime-corejs2
3 npm install --save @babel/runtime-corejs3

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 问题内容: 我是Webpack的新手。我想我做错了。我想使用babel将ES6函数转换为ES5函数。因此,我做了一些研究,发现了babel- loader。但是,我不确定自己在做什么。 我运行npm install babel-loader –save-dev并将其添加到我的package.json中 // package.json // webpack.config.js // app / in

  • 本文向大家介绍详解webpack 配合babel 将es6转成es5 超简单实例,包括了详解webpack 配合babel 将es6转成es5 超简单实例的使用技巧和注意事项,需要的朋友参考一下 今天接触了webpack,第一次使用webpack进行转码,竟然稀里糊涂就成功了,哈哈。 下面附上流程 创建个文件夹,初始化一下,首先全局安装webpack 然后安装babel 在当前文件夹内执行安装,然

  • 本文向大家介绍es6对es5有哪些方面的优化呢?相关面试题,主要包含被问及es6对es5有哪些方面的优化呢?时的应答技巧和注意事项,需要的朋友参考一下 引入了let和const解决了var变量提升带来的问题,同时引入箭头函数解决this访问问题。

  • 本文向大家介绍如何实现sleep的效果(es5或者es6)?相关面试题,主要包含被问及如何实现sleep的效果(es5或者es6)?时的应答技巧和注意事项,需要的朋友参考一下 参考回答: (1)while循环的方式 执行sleep(1000)之后,休眠了1000ms之后输出了1111。上述循环的方式缺点很明显,容易造成死循环。 (2)通过promise来实现 //先输出了111,延迟500ms后输

  • 本文向大家介绍详解设置Webstorm 利用babel将ES6自动转码成ES5,包括了详解设置Webstorm 利用babel将ES6自动转码成ES5的使用技巧和注意事项,需要的朋友参考一下 前言:ECMAScript 6是JavaScript语言的下一代标准,已经在2015年6月正式发布了。Mozilla公司将在这个标准的基础上,推出JavaScript 2.0。ES6的目标,是使得JavaSc

  • 本文向大家介绍js定义类的方法示例【ES5与ES6】,包括了js定义类的方法示例【ES5与ES6】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js定义类的方法。分享给大家供大家参考,具体如下: 以下是es5标准里定义类的方法: 运行结果: 上面这样用构造函数和原型混合的方法定义类,是为了每次new新实例时可以共享方法,不用创建function新实例。所以只有函数属性放在原型对象里定义,

  • 本文向大家介绍webpack使用 babel-loader 转换 ES6代码示例,包括了webpack使用 babel-loader 转换 ES6代码示例的使用技巧和注意事项,需要的朋友参考一下 本文介绍了webpack使用 babel-loader 转换 ES6代码示例,分享给大家,具体如下: 查询各个 loader的使用,可以在官网上查询。https://www.npmjs.com (一)安装

  • 本文向大家介绍将HTML格式的String转化为HTMLElement的实现方法,包括了将HTML格式的String转化为HTMLElement的实现方法的使用技巧和注意事项,需要的朋友参考一下 代码如下: 1、若将script放到head元素中,则加载脚本时,尚未加载div元素,此时会出现“document.getElementById(...) 为空或者不是对象”。 2、以上代码在chrome