babel核心知识点

Babel 是一个 JavaScript 编译器,主要用于将 ECMAScript 2015+ 版本的代码转换为向后兼容的 JavaScript 代码,以便在旧版本的浏览器或环境中运行。以下是 Babel 的核心知识点:

1. 基本概念

  • 编译器:Babel 本质上是一个编译器,它遵循编译器的一般流程,即解析(Parsing)、转换(Transformation)和生成(Code Generation)。
    • 解析:将源代码转换为抽象语法树(AST)。
    • 转换:对 AST 进行修改,例如将新的语法特性转换为旧版本支持的语法。
    • 生成:根据修改后的 AST 生成新的代码。
  • 插件(Plugins):Babel 的功能通过插件来实现。插件是对 AST 进行转换的函数,每个插件负责处理特定的语法转换。例如,@babel/plugin-transform-arrow-functions 插件可以将箭头函数转换为普通函数。
  • 预设(Presets):预设是一组插件的集合,用于方便地管理和配置多个插件。例如,@babel/preset-env 是一个常用的预设,它根据目标环境自动确定需要使用的插件。

2. 配置文件

Babel 可以通过配置文件来指定使用的插件和预设。常见的配置文件有 .babelrcbabel.config.js 等。

.babelrc 示例
{"presets": ["@babel/preset-env"],"plugins": ["@babel/plugin-transform-arrow-functions"]
}
babel.config.js 示例
module.exports = {presets: [["@babel/preset-env",{targets: {browsers: ["last 2 versions", "ie >= 11"]}}]],plugins: ["@babel/plugin-transform-arrow-functions"]
};

3. 常用预设

  • @babel/preset-env:根据目标环境自动确定需要使用的插件。可以通过 targets 选项指定目标浏览器或环境,例如 { "browsers": ["last 2 versions", "ie >= 11"] } 表示支持每个浏览器的最后两个版本以及 IE 11 及以上版本。
  • @babel/preset-react:用于处理 React 代码,包括 JSX 和 React 特定的语法。
  • @babel/preset-typescript:用于处理 TypeScript 代码,将 TypeScript 代码转换为 JavaScript 代码。

4. 常用插件

  • @babel/plugin-transform-arrow-functions:将箭头函数转换为普通函数。
// 转换前
const add = (a, b) => a + b;// 转换后
var add = function add(a, b) {return a + b;
};
  • @babel/plugin-transform-classes:将 ES6 类转换为 ES5 构造函数和原型方法。
// 转换前
class Person {constructor(name) {this.name = name;}sayHello() {console.log(`Hello, ${this.name}`);}
}// 转换后
var Person = function () {function Person(name) {this.name = name;}Person.prototype.sayHello = function () {console.log('Hello, ' + this.name);};return Person;
}();
  • @babel/plugin-proposal-object-rest-spread:支持对象的扩展运算符和剩余参数。
// 转换前
const { a, ...rest } = { a: 1, b: 2, c: 3 };
const newObj = { ...rest, d: 4 };// 转换后
var _objectWithoutProperties = function (obj, keys) {var target = {};for (var i in obj) {if (keys.indexOf(i) >= 0) continue;if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;target[i] = obj[i];}return target;
};
var a = _ref.a,rest = _objectWithoutProperties(_ref, ['a']);
var newObj = Object.assign({}, rest, { d: 4 });

5. 插件开发

Babel 插件本质上是一个函数,它接收一个 babel 对象作为参数,并返回一个包含 visitor 属性的对象。visitor 是一个对象,包含了对 AST 节点进行处理的方法。

以下是一个简单的 Babel 插件示例,用于将所有的字符串字面量转换为大写:

module.exports = function (babel) {const { types: t } = babel;return {visitor: {StringLiteral(path) {const newNode = t.stringLiteral(path.node.value.toUpperCase());path.replaceWith(newNode);}}};
};

6. 与构建工具集成

Babel 通常与构建工具(如 Webpack、Rollup 等)集成,以便在构建过程中自动进行代码转换。

Webpack 集成示例
const path = require('path');module.exports = {entry: './src/index.js',output: {path: path.resolve(__dirname, 'dist'),filename: 'bundle.js'},module: {rules: [{test: /\.js$/,exclude: /node_modules/,use: {loader: 'babel-loader',options: {presets: ['@babel/preset-env']}}}]}
};

通过以上核心知识点,你可以了解 Babel 的基本原理、配置方法、常用插件和预设,以及如何开发自己的插件和与构建工具集成。

作用介绍

Babel有了解过吗,请说说 Babe1的高的使用和原理?
了解过
bebeL用来作什么的?
,将高版本(ESHA) 3S 转为低版本16
将 Typescript 转为j5
-降级处理。polyfiLl,vita esbuild.roLlup
taro早期,就是使用 bobet将nerV、Peact,遇法转为小程序
<di→diew
自己想要的语法支持,options chatn2.

基础使用

babel、webpack,都有两种使用途径:1.命令行、2.node 环境下的api
@babel/cLi
插件化机制实现、预设
@babel./plugin-transfore-arrow-functiona
@babel/plugin-transfora-instanceof
但是,为了给开发者足够的便捷,b8581 又在插件的基锁上封装了一层,预设
-@babel/preset-env

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/78625.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javaScript--数据结构和算法

在 JavaScript 里&#xff0c;数据结构和算法是十分关键的部分&#xff0c;下面介绍几种常见的数据结构和对应的算法。 数组&#xff08;Array&#xff09; 数组是最基础的数据结构&#xff0c;用于存储一系列有序的数据。 // 创建数组 const arr [1, 2, 3, 4, 5];// 访问元素…

π0.5:带开放世界泛化的视觉-语言-动作模型

25年4月来自具身机器人创业公司 PI 公司的论文“π0.5: a Vision-Language-Action Model with Open-World Generalization”。 为了使机器人发挥作用&#xff0c;它们必须在实验室之外的现实世界中执行实际相关的任务。虽然视觉-语言-动作 (VLA) 模型在端到端机器人控制方面已…

使用 OpenCV 和 dlib 进行人脸检测

文章目录 1. 什么是 dlib2. 前期准备介绍2.1 环境准备2.2 dlib 的人脸检测器 3. 代码实现3.1 导入库3.2 加载检测器3.3 读取并调整图像大小3.4 检测人脸3.5 绘制检测框3.6 显示结果 4. 完整代码5. 优化与改进5.1 提高检测率5.2 处理 BGR 与 RGB 问题 6. 总结 人脸检测是计算机视…

spring 的PropertySource 类与 @PropertySource 注解详解与对比

PropertySource 类与 PropertySource 注解详解与对比 在这里插入图片描述 一、PropertySource 类详解 1. 类型与作用 类型&#xff1a;接口&#xff08;org.springframework.core.env.PropertySource&#xff09;作用&#xff1a;抽象配置数据源&#xff0c;提供统一的键值…

Java后端开发day37--源码解析:TreeMap可变参数--集合工具类:Collections

&#xff08;以下内容全部来自上述课程&#xff09; 1. TreeMap 1.1 须知 1.1.1 Entry 节点初始为黑色&#xff1a;提高代码阅读性 1.1.2 TreeMap中的成员变量 comparator&#xff1a;比较规则root&#xff1a;红黑树根节点的地址值size&#xff1a;集合的长度和红黑树…

基于Playwright的浏览器自动化MCP服务

一、服务定位与核心功能 github.com/executeautomation/mcp-playwright 是一个基于 Playwright&#xff08;微软开源的跨浏览器自动化测试框架&#xff09;的 Model Context Protocol (MCP) 服务&#xff0c;核心功能是将浏览器自动化能力集成到大语言模型&#xff08;LLM&…

OSPF网络协议

OSPF&#xff08;Open Shortest Path First&#xff09;是一种链路状态路由协议&#xff0c;属于IGP&#xff08;内部网关协议&#xff09;&#xff0c;用于在单一自治系统&#xff08;AS&#xff09;内动态分发路由信息。它通过计算最短路径&#xff08;基于Dijkstra算法&…

Ubuntu 22.04.4操作系统初始化详细配置

上一章节&#xff0c;主要讲解了Ubuntu 22.04.4操作系统的安装&#xff0c;但是在实际生产环境中&#xff0c;需要对Ubuntu操作系统初始化&#xff0c;从而提高系统的性能和稳定性。 一、查看Ubuntu系统版本和内核版本 # 查看系统版本 testubuntu:~$ sudo lsb_release -a Rel…

【Linux应用】开发板快速上手:镜像烧录、串口shell、外设挂载、WiFi配置、SSH连接、文件交互(RADXA ZERO 3为例)

【Linux应用】开发板快速上手&#xff1a;镜像烧录、串口shell、外设挂载、WiFi配置、SSH连接、文件交互&#xff08;RADXA ZERO 3为例&#xff09; 参考&#xff1a; ZERO 3 | Radxa Docs 大部分的Linux开发板等设备都大同小异 如树莓派、香橙派、STM32MP135的Linux开发板等 …

Redis使用总结

NoSQL 1.1为什么要用NoSQL 面对现在用户数据的急剧上升&#xff0c;我们需要对这些用户数据进行挖掘&#xff0c;传统的关系型数据库已经不适合这些 应用了.Nosql 的发展可以很了的处理这些大的数据. 1.2什么是NoSQL Not Only Sql->NoSQL(不仅仅是SQL) 非关系型数据库.随…

Unity ML-Agents + VScode 环境搭建 Windows

安装Unity 先去官网下载Unity Hub&#xff0c;然后安装在D盘就可以了&#xff0c;你需要手机上安装一个Unity Connect进行账号注册。 详细的注册可以参考&#xff1a; https://blog.csdn.net/Dugege007/article/details/128472571 注册好了以后登入电脑端的Unity Hub&#x…

Linux电源管理(2)_常规的电源管理的基本概念和软件架构

原文&#xff1a; Linux电源管理(2)_Generic PM之基本概念和软件架构 1. 前言 Linux系统中那些常规的电源管理手段&#xff0c;包括关机&#xff08;Power off&#xff09;、待机&#xff08;Standby or Hibernate&#xff09;、重启&#xff08;Reboot&#xff09;等。这些…

机器学习基础理论 - 分类问题评估指标

几个定义:混淆矩阵 TP: True Positives, 表示实际为正例且被分类器判定为正例的样本数FP: False Positives, 表示实际为负例且被分类器判定为正例的样本数FN: False Negatives, 表示实际为正例但被分类器判定为负例的样本数TN: True Negatives, 表示实际为负例且被分类…

在线教育系统开发常见问题及解决方案:源码部署到运营维护

当下&#xff0c;越来越多的教育机构、企业培训部门以及创业者&#xff0c;选择开发属于自己的在线教育系统。然而&#xff0c;从源码部署到实际运营&#xff0c;整个过程中常常会遇到一系列技术与管理难题。今天&#xff0c;笔者将从在线教育系统源码维护、运营等几个方向为大…

RAG(Retrieval-Augmented Generation,检索增强生成)

RAG&#xff08;Retrieval-Augmented Generation&#xff0c;检索增强生成&#xff09;是一种结合 信息检索 和 文本生成 的技术&#xff0c;旨在提升大语言模型&#xff08;LLM&#xff09;生成内容的准确性和时效性。其核心思想是&#xff1a;先检索相关知识&#xff0c;再基…

项目实战 -- 状态管理

redux基础 还记得好久好久之前就想要实现的一个功能吗&#xff1f; 收起侧边栏折叠菜单&#xff0c;没错&#xff0c;现在才实现 因为不是父子通信&#xff0c;所以处理起来相对麻烦一点 可以使用状态树或者中间人模式 这就需要会redux了 Redux工作流&#xff1a; 异步就…

Go语言之路————指针、结构体、方法

Go语言之路————指针、结构体、方法 前言指针结构体声明初始化使用组合引用结构体和指针结构体的标签 方法例子结合结构体总结 前言 我是一名多年Java开发人员&#xff0c;因为工作需要现在要学习go语言&#xff0c;Go语言之路是一个系列&#xff0c;记录着我从0开始接触Go…

[创业之路-390]:人力资源 - 社会性生命系统的解构与重构:人的角色嬗变与组织进化论

前言&#xff1a; 人、财、物、信息、机制、流程、制度、方法共同组合了一个持续的消耗资源、持续的价值创造、持续面临生存与发展、遗传与变异的社会性生命系统。 "人"是所有社会性生命系统最最基础性的要素&#xff0c;它弥漫在系统中多维立体空间的不同节点上&am…

JS执行器在UI自动化测试中的应用

前言 在进行UI自动化过程会遇到滚动条下拉、隐藏元素定位、只读属性元素的编辑、富文本处理等&#xff0c;此时可以使用JS执行器简化我们的一些处理操作。 具体应用 JS执行器的使用步骤&#xff1a; 1.先写个JS脚本&#xff0c;如果需要获取操作后的值&#xff0c;JS脚本前面…

解析Suna:全球首款开源通用AI智能体

导语&#xff1a; 嘿&#xff0c;哥们儿&#xff0c;最近 AI Agent 这块儿挺火的&#xff0c;有个叫 Suna 的开源项目冒出来挺快&#xff01;听说只用了 3 周就开发出来了&#xff0c;但功能上感觉已经能跟那个商业版的 Manus掰掰手腕了。它能帮你搞定浏览器自动化、管文件、爬…