me-*_*-me 9 javascript reactjs
我正在尝试创建一个更高阶的组件,但不断收到这个 eslint 警告。
组件定义缺少显示名称
我尝试添加如下所示的显示名称,但它仍然抱怨。
import React from 'react';
const HOC = props => (WC) => {
WC.displayName = 'test'
return (
<WC />
);
}
export default HOC;
Run Code Online (Sandbox Code Playgroud)
Shu*_*tri 13
你需要纠正两件事。
第一:修复功能组件声明的顺序。
第二:设置 displayName 为 HOC 返回的组件
const HOC = WC => {
const MyComp = (props) => {
return (
<WC {...props} />
);
}
MyComp.displayName = 'test'
return MyComp;
}
Run Code Online (Sandbox Code Playgroud)
一旦你进行了上述更改。你只需要像使用 HOC
const MyCompWithHoc = HOC(CompA);
Run Code Online (Sandbox Code Playgroud)
并将其渲染为
<MyCompWithHoc propsA={'A'} {...otherPropsYouWantToPass} />
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7414 次 |
| 最近记录: |