如何在升级后的react-native中使用装饰器

本文介绍了解决React Native 0.56+版本中使用ES7装饰器出现的错误方法。通过更新Babel版本及正确配置.babelrc文件,使项目能够支持装饰器语法。

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

情况

1.使用最新版的rn(0.56+)
2.旧版本rn升级到新版本(0.56+)

问题

导致无法使用es7装饰器,报如下错误

error: bundling failed: TypeError: Property right of AssignmentExpression expected node to be of a type ["Expression"] but instead got null复制代码
原因

新版本rn使用babel@7.0+,所以不能再使用原先的babel-plugin-transform-decorators-legacy(babel@6以下使用)


额外条件

很多人在运行

npm install --save-dev @babel/plugin-proposal-decorators
复制代码

后发现任然报上面的错误。这里安装版本有额外的条件,就是装饰器的版本要跟着babel的版本一样,并且用脚手架react-native-cli构建的时候使用时yarn install,所以安装的时候必须使用以下命令


yarn add @babel/plugin-proposal-decorators --dev
复制代码
配置.babelrc
{
  "presets": ["react-native"],
  "plugins":[["@babel/plugin-proposal-decorators", { "legacy": true }]]
}
复制代码

这里的配置跟原先的不一样

如何查看rn使用babel解析版本

在项目的目录下打开yarn.lock文件,即可查看版本号


结尾

走完以上步骤就能在rn中愉快地使用装饰器语法了


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值