利用TypeScript构建优雅的React Native项目

Posted 前端小词典

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用TypeScript构建优雅的React Native项目相关的知识,希望对你有一定的参考价值。

很长一段时间就想把ts引入公司的项目,但总是因为一些原因被搁置。接下来有机会重构之前的rn项目,借此机会正好可以引入ts,为了使后期的项目架构更加完善,近期我会梳理rn的一些知识点和新特性。

首先来介绍下TypeScript

  • 始于javascript,归于JavaScript 

  • 强大的工具构建 大型应用程序 

  • 先进的 JavaScript 

具体看官网传送门,毕竟今天的重点在如何使用

1.新建一个react native项目

 
   
   
 
  1. react-native init TSReactNativeDemo

项目结构

 
   
   
 
  1. ├── App.js

  2. ├── __tests__

  3. ├── android

  4. ├── app.json

  5. ├── index.js

  6. ├── ios

  7. ├── node_modules

  8. ├── package.json

  9. └── yarn.lock

然后测试下新建的项目是否能运行

 
   
   
 
  1. react-native run-android

  2. react-native run-ios

2.集成TypeScript

由于React Native Packager是通过Babel编译.js文件以及打包的,所以没办法直接使用.tsx。折中本思路就是,先用TypeScript的编译器tsc将.ts或.tsx文件编译成.js文件,再用React Native Packager编译打包即可。

首先我们安装TS依赖:

 
   
   
 
  1. yarn add -D typescript

然后需要安装types:

 
   
   
 
  1. yarn add -D @types/react @types/react-native

然后需要配置tsconfig.json,可以用如下命令生成:

 
   
   
 
  1. tsc --init --pretty --sourceMap --target es2015 --outDir ./lib --rootDir ./ --module commonjs --jsx react

生成的文件里面有具体每个参数的含义,也可以参考TS官网文档。

3.编写一个TS组件

还是一样的面孔,还是那个让我们魂牵梦绕的栗子—计数器(Counter.tsx)

 
   
   
 
  1. import * as React from 'react';

  2. import { Button, StyleSheet, Text, View } from 'react-native';

  3. interface Props {

  4.  name: string;

  5.  count?: number;

  6.  onInc?: () => void;

  7.  onDec?: () => void;

  8. }

  9. export default ({ name, count = 1, onInc, onDec }: Props) => (

  10.  <View style={styles.root}>

  11.    <Text>

  12.      Counter {name}: {count}

  13.    </Text>

  14.    <View>

  15.      <Button title="+" onPress={onInc || (() => {})} />

  16.      <Button title="-" onPress={onDec || (() => {})} />

  17.    </View>

  18.  </View>

  19. );

  20. // styles

  21. const styles = StyleSheet.create({

  22.  root: {

  23.    alignItems: 'center',

  24.    alignSelf: 'center',

  25.  },

  26.  buttons: {

  27.    flexDirection: 'row',

  28.    minHeight: 70,

  29.    alignItems: 'stretch',

  30.    alignSelf: 'center',

  31.    borderWidth: 5,

  32.  },

  33.  button: {

  34.    flex: 1,

  35.    paddingVertical: 0,

  36.  },

  37.  greeting: {

  38.    color: '#999',

  39.    fontWeight: 'bold',

  40.  },

  41. });

接下来就是利用ts编译器编译写好的.tsx个人建议在package.json中配置一下

 
   
   
 
  1. ...

  2. "scripts": {

  3.    "start": "node node_modules/react-native/local-cli/cli.js start",

  4.    "tsx":"./node_modules/.bin/tsc",

  5.    "test": "jest"

  6.  },

  7. ...

然后执行

 
   
   
 
  1. npm run tsx

由于ts默认的tsconfig.json中设置了

 
   
   
 
  1. "outDir": "./lib"

所以在项目根目录/lib下会生成编译后的.js文件如

 
   
   
 
  1. lib

  2. └── src

  3.        ├── Counter.js

  4.        └── Counter.js.map

4.引用编译后的Counter.js

最后一步就是在入口js中引用编译后的文件,然后打包测试即可。

总结

整体看来,ts的引入让我们前期多了几步操作,但这些问题都可以在自动化打包部署中用脚本帮我们完成,另外对于ts不熟悉,一些习惯了js弱类型的开发者来说这样的写法无疑就是没事找事。我不反驳这种观点,举几个例子

 
   
   
 
  1. interface Props {

  2.  onInc?: () => void;

  3. }

  4. ...

  5.    <View>

  6.      <Button title="+" onPress={onInc || (() => {})}

  7.    />

  8. ...

如果我这里没有规定onInc为可为空且无返回值的fun,并且在onPress中没有做undefind判断,页面在使用这个子组件的时候一旦传入的值是undefind就会导致奔溃。如果这些功能一个人做还好,多人协作,这样本可以避免的问题就会被无限放大。

ts的引入可以降低项目的维护成本,作为企业级的项目这是很有必要的

可能有人会拿ts和flow做比较,首先二者我都有使用过,总体的感觉ts更强大一点,个人建议还是使用ts

文章可能有很多不足的地方,希望大家指正,同时也希望大家可以多多交流,分享出更多的技术方案,谢谢~~

以上是关于利用TypeScript构建优雅的React Native项目的主要内容,如果未能解决你的问题,请参考以下文章

使用 Typescript 的 React Native/Xcode Release 不起作用

优雅的在vue中使用TypeScript

如何使用 GraphQL 构建 TypeScript+React 应用

在 React 和 TypeScript 中构建布局组件

如何使用 Typescript 构建 React Native 导航以进行属性传递

使用 create-react-app 和 Typescript 时如何在构建时加载 .md 文件?