bable转换html里面的js,javascript – 在Babel中转换插件与语法插件

本文探讨了在Webpack配置中使用Class属性的方法。详细解释了babel-plugin-syntax-class-properties和babel-plugin-transform-class-properties两个插件的作用,并说明了为什么通常需要同时使用这两个插件来实现从现代JavaScript到ES5的转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我想在我的webpack设置中使用Class属性.

继本书(www.survivejs.com)之后,我注意到作者在.babelrc文件中添加了2个插件:babel-plugin-syntax-class-properties以及babel-plugin-transform-class-properties.

查看语法类属性的babel文档,它指出:

Syntax only

This plugin only allows Babel to parse this syntax. If you

want to transform it then see transform-class-properties.

有什么不同?我需要两个吗?我的代码似乎只使用转换插件运行良好.

解决方法:

转型是一个三步过程:

>将源代码解析为AST

>更改/转换AST

>打印AST(转换为源代码)

语法插件是第1步所必需的:诸如类属性之类的提议引入了一种新语法,当前的JavaScript解析器无法对其进行解析.语法插件扩展了解析器,因此它理解新语法.

示例:想象一下,我引入了一个新的令牌@,例如in

@.foo();

JavaScript解析器无法将此代码解析为AST,因为当前@在该位置无效.所以我必须扩展解析器来解析它.

转换插件是第2步所必需的:现在解析了源代码,我们需要将新功能的AST节点转换为在当前JavaScript中有效的内容.

示例:我之前示例中的@是一种引用此方法的新方法.为了使它在不理解@的当前环境中工作,我需要转换并用它替换它,以便上面的例子变为

this.foo();

And do I need both?

如果要将代码转换为ES5,是的.

My code seem to run fine just with the transform plugin.

您可能正在使用已包含语法插件的预设.

标签:javascript,babeljs

来源: https://codeday.me/bug/20190716/1475592.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值