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