4

typescriptjavascript的超集,在javascript的基础上添加了可选的静态类型,非常适合团队开,这次我们尝试使用typescript来开发react-native应用。

搭建react-native开发环境

安装yarn和react-native命令行工具

npm install -g yarn react-native-cli

Yarn是Facebook提供的替代npm的工具,可以加速node模块的下载。React Native的命令行工具用于执行创建、初始化、更新项目、运行打包服务(packager)等任务。

React Native目前需要Xcode 7.0 或更高版本。你可以通过App Store或是到Apple开发者官网上下载。这一步骤会同时安装Xcode IDE和Xcode的命令行工具。

虽然一般来说命令行工具都是默认安装了,但你最好还是启动Xcode,并在Xcode | Preferences | Locations菜单中检查一下是否装有某个版本的Command Line Tools。Xcode的命令行工具中也包含一些必须的工具,比如git等。

搭建typescript开发环境

先安装typescript

npm install -g typescript

接下来安装typings
typings是typescript的依赖管理器,如果你使用sublime text或者vscode,会非常方便的补全代码

npm install -g typings

使用react-native命令行工具初始化react-native项目

react-native init ReactNativeApp

等待片刻后,进入刚刚新建的项目,创建一个名为"tsconfig.json" 的文件。tsconfig.json是一个 typescript 项目的配置文件,可以通过读取它来设置 ts 编译器的编译参数
内容如下:

{
    "compilerOptions": {
        "target": "es6",
        "allowJs": true,
        "jsx": "react",
        "outDir": "./dist",
        "sourceMap": true,
        "noImplicitAny": false
    },
    "include": [
        "typings/**/*.d.ts",
        "src/**/*.ts",
        "src/**/*.tsx"
    ],
    "exclude": [
        "node_modules"
    ]
}

在项目下新建一个目录"src",typescripe源代码就放在这里

现在安装typings依赖

typings install npm~react --save
typings install dt~react-native --globals --save

编写Hello world

在src目录下新建myview.tsx,内容如下

import * as React from "react"
import { Text } from 'react-native';

/**
 * Hello
 */
export default class Hello extends React.Component<null, null>{
    render() {
        return (
            <Text>Hello world!</Text>
        );
    }
}

返回根目录,编译刚刚写好的tsx文件

tsc

修改index.ios.js

import React, { Component } from 'react';
import Hello from './dist/myview';
import {
    AppRegistry,
    StyleSheet,
    Text,
    View
} from 'react-native';

export default class ReactNativeApp extends Component {
    render() {
        return (
            <View style={styles.container}>
                <Hello />
            </View>
        );
    }
}

const styles = StyleSheet.create({
    container: {
        flex: 1,
        justifyContent: 'center',
        alignItems: 'center',
        backgroundColor: '#F5FCFF',
    }
});

AppRegistry.registerComponent('ReactNativeApp', () => ReactNativeApp);

运行run-ios试试效果

react-native run-ios

运行效果:


作者信息
本文系Maxleap团队_云服务研发成员:xinghaidong 【原创】
MaxLeap博客首发:https://blog.maxleap.cn/archi...

相关推荐
ReactJS 开发过程中的一些使用心得
使用 React Native 构建类似 Tinder 的加载器
React Native 中的 Android 原生模块
欢迎扫一扫二维码,关注我们的微信订阅号:
图片描述


力谱云
2.6k 声望226 粉丝

力谱云 - 让每个企业都拥有自己的移动电商平台