加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

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

发布时间:2019-05-11 01:58:31 所属栏目:建站 来源:wuming
导读:抛转引用 现在越来越多的项目放弃了javascript,而选择拥抱了typescript,就比如我们熟知的ant-design就是其中之一。面对越来越火的typescript,我们公司今年也逐渐开始拥抱typescript。至于为什么要使用typescript?本文不做深入探讨。 这篇文章比较全面

遇到这种情况,需要我们在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”。

有状态组件

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读