react-perf/jsx-no-jsx-as-prop Perf
它的作用
防止在当前方法中局部定义的 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} />如何使用
To enable this rule using the config file or in the CLI, you can use:
json
{
"plugins": ["react-perf"],
"rules": {
"react-perf/jsx-no-jsx-as-prop": "error"
}
}ts
import { defineConfig } from "oxlint";
export default defineConfig({
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版本
此规则在 v0.2.3 中添加。
