设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

React项目从Javascript到Typescript的迁移经验总结(4)

发布时间:2019-05-08 04:35 所属栏目:21 来源:wuming
导读:遇到这种情况,需要我们在tsconfig.json中lib这个配置项加入一个dom库,如下: { compilerOptions:{ lib:[ dom, ..., esNext ] } } 文件中的标红问题 关于这个问题,我们需要分两种情况来考虑,第一种是.ts的文件,

遇到这种情况,需要我们在tsconfig.json中lib这个配置项加入一个dom库,如下:

  1. {  
  2.     "compilerOptions":{  
  3.         "lib":[  
  4.             "dom",  
  5.             ...,  
  6.             "esNext"  
  7.         ]  
  8.     }  
  9. }  

文件中的标红问题

关于这个问题,我们需要分两种情况来考虑,第一种是.ts的文件,第二种是.tsx文件。下面来看一下具体是哪些注意的点(Ps:以下提到的注意的点并不能完全解决文件中标红的问题,但是可以解决大部分标红的问题):

第一种:.ts文件

这种文件在你的项目比较少,比较容易处理,根据实际情况去加一下类型限制,没有特别需要讲的。

第二种:.tsx文件

这种情况都是react组件了,而react组件又分为无状态组件和有状态组件组件,所以我们分开来看。

无状态组件

对于无状态组件,首先得限制他是一个FunctionComponent(函数组件),其次限制其props类型。举个🌰:

  1. import React, { FunctionComponent, ReactElement } from 'react';  
  2. import {LoadingComponentProps} from 'react-loadable';  
  3. import './style.scss';  
  4. interface LoadingProps extends LoadingComponentProps{  
  5.   loading:boolean,  
  6.   children?:ReactElement  
  7. }  
  8. const Loading:FunctionComponent<LoadingProps> = ({loading=true,children})=>{  
  9.   return (  
  10.     loading?<div className="comp-loading">  
  11.       <div className="item-1"></div>  
  12.       <div className="item-2"></div>  
  13.       <div className="item-3"></div>  
  14.       <div className="item-4"></div>  
  15.       <div className="item-5"></div>  
  16.     </div>:children  
  17.   )    
  18. }  
  19. export default Loading;  

其中你要是觉得FunctionComponent这个名字比较长,你可以选择用类型别名“SFC”或者“FC”。

有状态组件

对于有状态组件,主要注意三点:

  1. props和state都要做类型限制
  2. state用readonly限制“this.state=**”的操作
  3. 对event对象做类型限制 
  1. import React,{MouseEvent} from "react";  
  2. interface TeachersProps{  
  3.   user:User  
  4. }  
  5. interface TeachersState{  
  6.   pageNo:number,  
  7.   pageSize:number,  
  8.   total:number,  
  9.   teacherList:{  
  10.     id: number,  
  11.     name: string,  
  12.     age: number,  
  13.     sex: number,  
  14.     tel: string,  
  15.     email: string  
  16.   }[]  
  17. }  
  18. export default class Teachers extends React.PureComponent<TeachersProps,TeachersState> {  
  19.     readonly state = {  
  20.         pageNo:1,  
  21.         pageSize:20,  
  22.         total:0,  
  23.         userList:[]  
  24.     }  
  25.     handleClick=(e:MouseEvent<HTMLDivElement>)=>{  
  26.         console.log(e.target);  
  27.     }  
  28.     //...省略部分代码  
  29.     render(){  
  30.         return <div onClick={this.handleClick}>点击我</div>  
  31.     }  
  32. }  

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读