当我们使用react的比较新的18.x版本,我们还用的typescript,我们可能会比较习惯使用(const test: React.FC<PropsWithChildren<FormProps >>)
interface MenuProps{
modalVisible: boolean;
onCancel: () => void;
onConfirm: (form: any) => void;
}
const test: React.FC<PropsWithChildren< MenuProps**>**> = (props) => {
return(<div>test</div>)
}
这种写法,而不想使用 (extends React.Componen)
class Demo extends React.Component {
render() {
return(<div>test</div>)
}
}
我们要如何去改呢?官方文档是react.component 的挂载render的写法,那么我下面举个例子简单讲一下
antdesign 官方文档该树形组件控件地址:Tree - Ant Design多层次的结构列表。https://3x.ant.design/components/tree-cn/
效果图如下
data:image/s3,"s3://crabby-images/860c0/860c05f108e341a9b0acaadf7f302d667154feca" alt=""
1官方文档的树形控件写法
data:image/s3,"s3://crabby-images/6ad23/6ad2351f6992196671834b53e653e34ffc813ddd" alt=""
一下是修改步骤:
(1)把最外层写法修改,主要写法改一下render
data:image/s3,"s3://crabby-images/da903/da903b539d7404f1c6b74ef2b7ad5af72e8d23aa" alt=""
改为
data:image/s3,"s3://crabby-images/b90a4/b90a41b88ab01dbfd46d259c91d9115bece6fb97" alt=""
(2)修改state
data:image/s3,"s3://crabby-images/af106/af10616fa8203f1c26b631f58fa5ba28b028050b" alt=""
data:image/s3,"s3://crabby-images/b0234/b02349ba7af54b195e31f633f4a0e030ba0c89b9" alt=""
(3)把所有调用原来this.state的地方改一下,其他函数同样如下
data:image/s3,"s3://crabby-images/d66f7/d66f78a7d4e2aad299d69de011fcc3c29b92b940" alt=""
改为
data:image/s3,"s3://crabby-images/89647/89647f94aef0abccbfd02bce309c72e1df537f8d" alt=""
对比图如下
data:image/s3,"s3://crabby-images/7f196/7f196b36f2f8b548e80f404a354bbbba57c954d9" alt=""
(4)主要原来所有的中的所有this.xx调用函数方法去掉this (this.onExpand===》onExpand),还有把所有调用this.state.xx也把this.state去掉(如:this.state)
(4)相关依赖的引入保持不变,但是ts需要一些类型校验比较仔细,所以有些依赖的引入要注意一下,有些飘红的地方注意下类型问题
data:image/s3,"s3://crabby-images/0f336/0f3360b4e5400a6aeeeadc5357db53a30dced645" alt=""
(5)修改后的完整版如下
data:image/s3,"s3://crabby-images/67f81/67f81c4250e3f2898d245b679524d19c8184ab65" alt=""