使用TypeScript开发ReactNative应用的简单示例
最近小小尝试了下 ReactNative + TypeScript 开发APP,爬了无数坑之后总算弄出来个结果,重要的地方记录下,后面会附上示例代码:
1、开发工具的选择
windows 平台我接触的开发工具主要三个,
WebStorm,Intellij IDEA 2016.2 版本,https://www.jetbrains.com/
这两个我都试过,开发完全没问题的,还有PHPStorm估计也行吧,没试过。
另外还有一个是VisualStudioCode:https://code.visualstudio.com/b?utm_expid=101350005-27.GqBWbOBuSRqlazQC_nNSRg.1
对与 iOS 平台应该是不用选的就是 Nuclide 了吧,我是没用过哈,不知道怎么用,不过用过 Atom 感觉还是很酷的。
平时习惯用 jetbrains 的 IDE ,每个都绝对神器,VisualCode 感觉实在太难用了,坚持了一段时间还是放弃了。
下面示例都是用的 Intellij IDEA 2016.2
预览下:
经过一番配置后,import 等导入和代码提示等等都是没问题的
2、基础开发环境安装
这个我就不说了,直接看这个网站就行了上面已经写得很完善了 http://reactnative.cn/ ,照着文档安装配置应该没什么问题的,文档看不懂的话网站的站长博客里面还有全套的视频讲解非常详细了,地址:http://reactnative.cn/post/759。
3、安装 TypeScript 开发环境
- # 先 cd 到你的项目目录,如 myproject 目录下再执行下面命令
- npm install -g typescript
- npm install typescript
- tsc --init
- # 未安装 tsd 则先安装再进行项目初始化
- npm install -g tsd
- tsd init && tsd install react-native --save
tsd 初始化安装后,会生成 tsconfig.json 文件,貌似 react-native 初始化新项目的时候就有这么个文件来着,忘了,如果tsd初始化之前已存在该文件可直接删除。
查看 tsconfig.json 文件
- {
- "compilerOptions": {
- "target": "es6",
- "allowJs": true,
- "jsx": "react",
- //"outDir": "artifacts",
- //"rootDir": "src",
- "sourceMap": false,
- "noImplicitAny": false
- },
- "filesGlob": [
- "typings/**/*.d.ts",
- "src/**/*.ts",
- "src/**/*.tsx"
- ],
- "exclude": [
- "node_modules"
- ]
- }
个人建议是 outDir 参数建议不要设置,使用默认值就行,这样每次修改 .ts 文件后就会直接在当前目录下生成同名的 es6语法编译后 .js 文件,当 index.android.js 入口文件加载项目文件时则很方便,如下图:
以上配置完成就可以开始使用 TypeScript 开发了。
简单做了个 List 加载文章列表的功能,实现起来很简单方便,和原生Android开发比起来简直快了太多太多。
不过一开始遇到了很多坑,主要还是由于对 TypeScript 不太熟悉
如 style 的设置,总是提示类型错误:
- Error:(20, 15) TS2322:Type '{ flex: number; flexDirection: string; }' is not assignable to type 'ViewStyle'.
- Types of property 'flexDirection' are incompatible.
- Type 'string' is not assignable to type '"row" | "column" | "row-reverse" | "column-reverse"'.
- Type 'string' is not assignable to type '"column-reverse"'.
类似上面这种错误,很是莫名其妙,搞了好半天才明白原来样式参数配置是需要进行类型转换,这也是 TypeScript很特色的地方啦
如下面这样:
4、TypeScript 跟 ReactNative 开发的关系
最后说一下这两者是如何发生关系的,可能还有跟我一样的小白还没弄清楚,我就按照自己的理解来说啦,
你用 TypeScript 语法写的 .ts .tsx 等后缀的程序是不能直接运行的,而是会被 tsconfig.json 配置中的 “target”: “es6”, 这项配置转换为 es6 语法的 .js 文件。
TypeScript 中的 import 只会加载 .ts .tsx 后缀的文件,而 Javascript 中的 import 只能加载 .js 等后缀的文件,
所以,当 ReactNative 启动时,首先加载入口文件,如 index.android.js ,代码如下:
- import { AppRegistry } from 'react-native';
- import IndexNavigator from './application/src/controller/navigator/IndexNavigator';
- AppRegistry.registerComponent('mogudan', () => IndexNavigator);
其中 import IndexNavigator from … 这一行加载的不是 IndexNavigator.ts 而是编译后生成的 IndexNavigator.js 文件,下面对比两个文件的差异:
IndexNavigator.ts
- /**
- * Created by ZHOUZ on 2016-08-26.
- */
- import * as React from 'react';
- import {Navigator} from 'react-native';
- import IndexPage from '../page/IndexPage'
- export default class IndexNavigator extends React.Component<any, any> {
- render() {
- let defaultName = 'IndexPage3311113';
- let defaultComponent = IndexPage;
- return (
- <Navigator
- initialRoute={{ name: defaultName, component: defaultComponent }}
- configureScene={(route) => Navigator.SceneConfigs.VerticalDownSwipeJump }
- renderScene={(route: any, navigator) => {
- let Component = route.component;
- return <Component {...route.params} navigator={navigator} />
- }}
- />
- );
- }
- }
IndexNavigator.js
为自动编译后生成的es6语法的 javascript 代码
- "use strict";
- var __assign = (this && this.__assign) || Object.assign || function(t) {
- for (var s, i = 1, n = arguments.length; i < n; i++) {
- s = arguments[i];
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
- t[p] = s[p];
- }
- return t;
- };
- /**
- * Created by ZHOUZ on 2016-08-26.
- */
- const React = require('react');
- const react_native_1 = require('react-native');
- const IndexPage_1 = require('../page/IndexPage');
- class IndexNavigator extends React.Component {
- render() {
- let defaultName = 'IndexPage3311113';
- let defaultComponent = IndexPage_1.default;
- return (React.createElement(react_native_1.Navigator, {initialRoute: { name: defaultName, component: defaultComponent }, configureScene: (route) => react_native_1.Navigator.SceneConfigs.VerticalDownSwipeJump, renderScene: (route, navigator) => {
- let Component = route.component;
- return React.createElement(Component, __assign({}, route.params, {navigator: navigator}));
- }}));
- }
- }
- Object.defineProperty(exports, "__esModule", { value: true });
- exports.default = IndexNavigator;
大概就是这样了,最最后放上我做的示例代码,只包含 application 目录下的文件,android,ios 目录都是 react-native 自动生成的大家都一样的。
文件下载地址: http://download.csdn.net/detail/zsjangel/9618350
补充一个问题,开发时使用 fetch 会遇到提示找不到的解决办法,
http://blog.csdn.net/zhouzme/article/details/52390197
使用TypeScript开发ReactNative应用的简单示例的更多相关文章
- TypeScript开发ReactNative之fetch函数的提示问题
使用TypeScript开发ReactNative时,发现在类中调用 fetch 函数时IDE可能会提示找不到,无法加载,特别是当类中存在同名的 fetch 成员方法时更是郁闷了,虽然程序是可以执行的 ...
- zookeeper Eclipse 开发环境搭建及简单示例
一,下载Zookeeper安装包 从官方网站下载稳定版安装包后,解压. 其中ZK_HOME 为:D:\Program Files\zookeeper-3.4.9 二,启动Zookeeper Serve ...
- 3D开发基础知识和简单示例
引言 现在物联网概念这么火,如果监控的信息能够实时在手机的客服端中以3D形式展示给我们,那种体验大家可以发挥自己的想象. 那生活中我们还有很多地方用到这些,如上图所示的Kinect 在医疗上的应用,当 ...
- 2017.2.20 activiti实战--第二章--搭建Activiti开发环境及简单示例(二)简单示例
学习资料:<Activiti实战> 第一章 搭建Activiti开发环境及简单示例 2.5 简单流程图及其执行过程 (1)leave.bpmn 后缀名必须是bpmn.安装了activiti ...
- [xfire]使用xfire开发webservice的简单示例
目前项目上有用到xfire,所以临时看了些xfire的资料和示例,自己照着写了一个简单示例. xfire在2007年后已经停止更新,正式更名为apache cxf,也可以说是xfire2.0. xfi ...
- 如何用TypeScript开发微信小程序
微信小程序来了!这个号称干掉传统app的玩意儿虽然目前处于内测阶段,不过目前在应用号的官方文档里已经放出了没有内测号也能使用的模拟器了. 工具和文档可以参考官方文档:https://mp.weixin ...
- ReactNative之结合具体示例来看RN中的的Timing动画
今天继续更新RN相关的博客.上篇博客详细的聊了RN中关于Flex布局的相关东西,具体请参见<ReactNative之参照具体示例来看RN中的FlexBox布局>.本篇博客继续更新RN的动画 ...
- iOS开发多线程篇—多线程简单介绍
iOS开发多线程篇—多线程简单介绍 一.进程和线程 1.什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内 比如同时打开QQ.Xcod ...
- iOS开发UI篇—UITabBarController简单介绍
iOS开发UI篇—UITabBarController简单介绍 一.简单介绍 UITabBarController和UINavigationController类似,UITabBarControlle ...
随机推荐
- 使用Oracle 9i工具管理数据库 - 初学者系列 - 学习者系列文章
前面介绍了Oracle 9i的安装,本文大概介绍下Oracle 9i提供的管理工具的使用. 1 打开数据库配置工具 2 下一步 3 下一步 4 下一步.这里输入数据库名和SID 5 下一步 6 下一步 ...
- Inno Setup connection to the database and create
原文 Inno Setup connection to the database and create Description: the first half of this program in I ...
- SQLCMD的介绍
原文:SQLCMD的介绍 sqlcmd -S SERVERNAME -U USERNAME -P PASSWORD -i filename.sql 下面的内容是详细介绍sqlcmd的,有兴趣的朋友可以 ...
- Asp.Net MVC页面静态化功能实现二:用递归算法来实现
上一篇提到采用IHttpModule来实现当用户访问网站的时候,通过重新定义Response.Filter来实现将返回给客户端的html代码保存,以便用户下一次访问是直接访问静态页面. Asp.Net ...
- linux find命令之exec
find是我们很常用的一个Linux命令,但是我们一般查找出来的并不仅仅是看看而已,还会有进一步的操作,这个时候exec的作用就显现出来了. exec解释: -exec 参数后面跟的是command ...
- 【值得收藏】数据分析和可视化软件IDL的学习资料汇编【可免费下载】
IDL学习教程 IDL 是一种数据分析和图像化应用程序及编程语言,最初在七十年代后期用于帮助科学家分析火星探险卫星发回的数据.此后,IDL得到广泛运用,使用者日众.IDL能使用户可以迅速且方便地运用此 ...
- Web前端开发的一点记录
工欲善其事必先利其器,开发工具选择Sublime Text 简称(ST) 本文所说的均在Windows NT 环境下使用的ST3运行. ST的Package Control安装方法: 1. 直接输入p ...
- C#编程总结
C#编程总结--总目录 多年的C#实战经历,希望通过一个系列课程对C#编程做系统总结. 总结过去,展望未来.新的一年,新的征程,新的开始! 希望我们在2014梦想成真,马到成功! 1.C#编程总结(一 ...
- OO设计
Todd.log - a place to keep my thoughts on programming 评OO设计 昨天在微博上看到InfoQ提供了一本新书<完美软件开发:方法与逻辑> ...
- usaco1.1.1Your Ride Is Here(入门题)
一下是我很久很久之前刷的题目...随便扔在这里啦.. Description 一个众所周知的事实,在每一慧星后面是一个不明飞行物UFO.这些不明飞行物时常来收集来自在地球上忠诚的支持者.不幸的是,他们 ...