react-perf/jsx-no-new-object-as-prop 性能
作用
防止将当前方法局部定义的对象用作 JSX props 的值。
为什么这不好?
将本地定义的对象用作 props 的值可能会导致非预期的重新渲染和性能问题。每当父组件渲染时,都会创建一个新的对象实例,从而导致子组件不必要地重新渲染。这也会使代码更难维护,因为组件的 props 传递不够一致。
示例
以下是此规则的错误代码示例:
jsx
<Item config={{}} />
<Item config={new Object()} />
<Item config={Object()} />
<Item config={this.props.config || {}} />
<Item config={this.props.config ? this.props.config : {}} />
<div style={{display: 'none'}} />以下是此规则的正确代码示例:
jsx
<Item config={staticConfig} />如何使用
To enable this rule using the config file or in the CLI, you can use:
json
{
"plugins": ["react-perf"],
"rules": {
"react-perf/jsx-no-new-object-as-prop": "error"
}
}ts
import { defineConfig } from "oxlint";
export default defineConfig({
plugins: ["react-perf"],
rules: {
"react-perf/jsx-no-new-object-as-prop": "error",
},
});bash
oxlint --deny react-perf/jsx-no-new-object-as-prop --react-perf-plugin版本
此规则是在 v0.2.3 中添加的。
