react-perf/jsx-no-jsx-as-prop 性能
它做了什么
禁止将当前方法中本地定义的 JSX 元素用作 JSX 属性的值。
为什么这是不好的?
将本地定义的 JSX 元素用作属性值可能导致意外的重新渲染和性能问题。每当父组件重新渲染时,都会创建一个新的 JSX 元素实例,从而导致子组件不必要的重新渲染。这还使得代码更难维护,因为组件的属性传递不再一致。
示例
此规则的错误代码示例:
jsx
<Item jsx={<SubItem />} />
<Item jsx={this.props.jsx || <SubItem />} />
<Item jsx={this.props.jsx ? this.props.jsx : <SubItem />} />此规则的正确代码示例:
jsx
<Item callback={this.props.jsx} />如何使用
要通过配置文件或命令行启用此规则,可以使用:
json
{
"plugins": ["react-perf"],
"rules": {
"react-perf/jsx-no-jsx-as-prop": "error"
}
}bash
oxlint --deny react-perf/jsx-no-jsx-as-prop --react-perf-plugin