Babel transform-runtime

本文详细介绍了Babel的@babel/plugin-transform-runtime及其配套的@babel/runtime。使用它们可以避免辅助函数的重复定义,减少代码体积,但可能不支持实例化方法且存在性能影响。文章涵盖安装配置、配置项讲解以及优缺点分析。
摘要由CSDN通过智能技术生成

Babel @babel/plugin-transform-runtime

本节我们来学习 @babel/plugin-transform-runtime 和 @babel/runtime 。

Babel 中使用辅助函数来实现常见功能,例如 _extend() 函数,每个编译后的文件都需要定义它所需要使用的辅助函数。但这样显然会造成很多重复,所以 Babel 把所有的辅助函数都封装于 @babel/runtime,每个编译后的文件只需要引用 @babel/runtime 即可。

@babel/runtime 插件可以将工具函数的代码转换成 require 语句,指向为对 @babel/runtime 的引用。每当要转译一个 API 时,都要手动加上 require(’@babel/runtime’)。简单说 @babel/runtime 更像是一种按需加载的实现,比如哪里需要使用 Promise,只要在这个文件头部添加如下代码即可:

require Promise from '@babel/runtime/core-js/promise'

而为了方便使用 @babel/runtime 插件,解决手动 require 的苦恼。它会分析我们的 ast 中,是否有引用 @babel/runtime (通过映射关系),如果有就会在当前模块顶部插入我们需要的垫片。

transform-runtime 是利用插件自动识别并替换代码中的新特性,所以不需要再引入,只需要装好 @babel/runtime 和配置 plugin 就可以了。

安装配置

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值