在上一篇文章中,我们学会了如何搭建React Native的环境(React Native入门教程(笔记) 1 – 开发环境搭建),不知道你们是否搭建好了呢,如果还没有,那么快动起小手,来体验RN带给我们的乐趣。

欢迎加入React Native讨论群:120663591

由于我也没怎么接触过js和css,所以就用自己的方式来学习,所以文章中有错误在所难免,如果您发现了错误,请及时在文章底下评论。我个人比较合适的学习方式是直接开发,遇到什么不会就去查,先把大概怎么写混熟,等到可以熟练写出程序之后,再去重新跟着基础查漏补缺。 这样做的原因是,对于初学者,直接给出许多属性,是记不住的,系统的学下来之后,如果没有大量联系,最终只有忘记,所以给自己一个编程的环境,告诉自己在开发,而不是单纯的学,这样也算是个捷径吧。

转载请注明出处:http://blog.csdn.net/wingichoy/article/details/51810882

电影介绍界面

本次教程的项目使用的是facebook的官方例子来学习,是一个电影上映的界面,通过这个例子,你可以学习到基本组件的使用,以及样式的改写。官方文档链接

首先,打开我们init好的项目,可以看到有index.android.js和index.ios.js两个js文件,分别对应android的界面和ios的界面:



打开index.android.js,对其中初始化代码进行分析。

可以看到初始化代码基本分四个部分:

1.导入部分

2.视图部分

3.样式部分

4.注册部分

1.导入部分

//导入React
import React, { Component } from 'react';
//导入各个组件
import {
AppRegistry, //注册器
StyleSheet, //style
Text, //Text 相当于android的TextView
TextInput, //输入框 相当于android的EditText
View, //基本的视图容器
Image, //图片组件 相当于android的ImageView } from 'react-native';

此部分是将需要用的到组件导入,分别类似于:

#include "stdio.h"  //c语言
import com.wing.* //java语言

2.视图部分

class My extends Component {
render() {
return (
//设置一个跟容器
<View style={styles.container}>
//设置3个文本组件,样式分别引用各自的style
<Text style={styles.welcome}>
Welcome to React Native!
</Text>
<Text style={styles.instructions}>
To get started, edit index.android.js
</Text>
<Text style={styles.instructions}>
Shake or press menu button for dev menu
</Text>
</View>
);
}
}

在这一部分,类似于Android的Activity,也就是一个程序的界面。对比Android来说呢,好比是Activity动态添加的View,也就是说视图的样式是默认的。他的样式由 styles(相当于Android的xml布局文件)决定。以上代码的意思就是说在主容器内添加了两个Text控件和一个Image控件,他们的样式分别由各自的style决定。

3.样式部分

//定义一个StyleSheet常量
const styles = StyleSheet.create({
//设置容器样式
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
//设置各自的样式,下同
welcome: {
fontSize: 20,
textAlign: 'center',
margin: 10,
},
instructions: {
textAlign: 'center',
color: '#333333',
marginBottom: 5,
},
});

此部分为各个组件的样式定义,语法上跟CSS大同小异,由于我也不太熟悉CSS的属性,所以用到的时候去查,多写几遍应该就记住了,孰能生巧嘛。

在此部分,相当于Android里面的xml文件,fontSize对应android:textSize。相信你很轻易就可以看明白。

4.注册部分


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

每个应用必须进行注册以后才可以渲染视图,每个APP只需要渲染一次即可。

开始制作第一款App,电影介绍

由于电影介绍,需要有电影的名称,年份,海报等。 所以我们现在本地模拟一个数据:

var MOVIES_DATA=[
{
title: 'Warcraft',
year: '2016',
img: 'http: //b.hiphotos.baidu.com/baike/pic/item/b03533fa828ba61ed1b6ccc84634970a314e59f8.jpg'
}
];

由于在程序里使用到了Image等组件,所以需要进行导入

import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
View,
Image,
} from 'react-native';

之后就可以编写界面,在容器里加入我们的组件。

class WingProject extends Component {
render() {
//获取模拟的电影数据
var movie = MOVIES_DATA[0];
return (
//添加主容器 并设置style
<View style={styles.container}>
//添加各个组件,并设置style
<Text style = {styles.title}>{movie.title}</Text>
<Text style = {styles.title}>{movie.year}</Text>
<Image source={{uri:movie.img}}
style = {styles.image}
/>
</View>
);
}
}

完成之后,接下来定义style

const styles = StyleSheet.create({
//设置主容器的布局
container: {
flex:1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
//image必须设置大小,不然图片就不会显示
image:{
width:400,
height:600,
},
//设置字体大小为20
title:{
fontSize:20,
}
});

在程序的最后,对应用进行注册操作:

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

运行APP

编码已经完成,在cmder里键入 run-android命令运行以下试试吧!

可以看到APP已经运行了 界面如下:

哈哈 有木有很开熏~~~

如果你喜欢我的博客,请评论或者点击关注,谢谢!

下一篇: React Native入门教程 3 – Flex布局

React Native入门教程2 -- 基本组件使用及样式的更多相关文章

  1. React Native入门教程 3 -- Flex布局

    上一篇文章中介绍了基本组件的使用 React Native入门教程(笔记) 2 – 基本组件使用及样式 本节内容将继续沿用facebook官方例子介绍如何使用Flexbox布局把界面设计的多样化. 转 ...

  2. React Native入门教程 1 -- 开发环境搭建

    有人问我为啥很久不更新博客..我只能说在学校宿舍真的没有学习的环境..基本上在宿舍里面很颓废..不过要毕业找工作了,我要渐渐把这个心态调整过来,就从react-native第一篇博客开始.话说RN也出 ...

  3. React Native 入门基础知识总结

    中秋在家闲得无事,想着做点啥,后来想想,为啥不学学 react native.在学习 React Native 时, 需要对前端(HTML,CSS,JavaScript)知识有所了解.对于JS,可以看 ...

  4. 基于Nodejs生态圈的TypeScript+React开发入门教程

    基于Nodejs生态圈的TypeScript+React开发入门教程   概述 本教程旨在为基于Nodejs npm生态圈的前端程序开发提供入门讲解. Nodejs是什么 Nodejs是一个高性能Ja ...

  5. React Native入门-刘望舒

    React Native入门(一)环境搭建与Hello World React Native入门(二)Atom+Nuclide安装.配置与调试 React Native入门(三)组件的Props(属性 ...

  6. React实例入门教程(1)基础API,JSX语法--hello world

      前  言 毫无疑问,react是目前最最热门的框架(没有之一),了解并学习使用React,可以说是现在每个前端工程师都需要的. 在前端领域,一个框架为何会如此之火爆,无外乎两个原因:性能优秀,开发 ...

  7. 【REACT NATIVE 系列教程之十二】REACT NATIVE(JS/ES)与IOS(OBJECT-C)交互通信

    http://blog.csdn.net/xiaominghimi/article/details/51586492 一用到跨平台的引擎必然要有引擎与各平台原生进行交互通信的需要.那么Himi先讲解R ...

  8. 【原创】React实例入门教程(1)基础API,JSX语法--hello world

    前  言 毫无疑问,react是目前最最热门的框架(没有之一),了解并学习使用React,可以说是现在每个前端工程师都需要的. 在前端领域,一个框架为何会如此之火爆,无外乎两个原因:性能优秀,开发效率 ...

  9. React Native之本地文件系统访问组件react-native-fs的介绍与使用

    React Native之本地文件系统访问组件react-native-fs的介绍与使用 一,需求分析 1,需要将图片保存到本地相册: 2,需要创建文件,并对其进行读写 删除操作. 二,简单介绍 re ...

随机推荐

  1. iOS核心面试题

    1,请简述你对协议的理解?    protocol无论是在那个领域都是一种约束,规范.在OC中的协议主要用于在各个类之间进行回调传值. 协议有 委托方,代理方, 委托方是协议的制定者,需要声明协议的方 ...

  2. oracle之子查询、创建用户、创建表、约束

      子查询                                    子查询可以分为单行子查询和多行子查询   单行子查询           [1] 将一个查询的结果作为另外一个查询的条 ...

  3. numpy.random中的shuffle和permutation以及mini-batch调整数据集(X, Y)

    0. numpy.random中的shuffle和permutation numpy.random.shuffle(x) and numpy.random.permutation(x),这两个有什么不 ...

  4. 转:Kafka 客户端TimeoutException问题之坑

    原文出自:http://www.jianshu.com/p/2db7abddb9e6 各种TimeoutException问题 会抛出org.apache.kafka.common.errors.Ti ...

  5. Zookeeper和Chubby【分布式协调系统】

    前言(对于协调系统来说其客户端往往是分布式集群) 大规模分布式系统需要解决各种类型的协调需求: 当集群中有新的进程或服务器加入时,如何探测到它的加入?如何能够自动获取配置参数? 当配置信息被某个进程或 ...

  6. python socket网络编程之粘包问题详解

    一,粘包问题详情 1,只有TCP有粘包现象,UDP永远不会粘包 你的程序实际上无权直接操作网卡的,你操作网卡都是通过操作系统给用户程序暴露出来的接口,那每次你的程序要给远程发数据时,其实是先把数据从用 ...

  7. 【图文详解】Hadoop集群搭建(CentOs6.3)

    本文主要详细地描述了hadoop集群的搭建以及一些配置文件的说明,用于自己复习以及供新人学习,若有错误之处还请指出. 前期准备 先给出我的集群架构: 到hadoop官网下载好hadoop安装包http ...

  8. geotrellis使用(四十)优雅的处理请求超过最大层级数据

    前言 要说清楚这个题目对我来说可能都不是一件简单的事情,我简单尝试. 研究 GIS 的人应该都清楚在 GIS 中最常用的技术是瓦片技术,无论是传统的栅格瓦片还是比较新颖的矢量瓦片,一旦将数据切好瓦片就 ...

  9. leetcode刷题笔记326 3的幂

    题目描述: 给出一个整数,写一个函数来确定这个数是不是3的一个幂. 后续挑战:你能不使用循环或者递归完成本题吗? 题目分析: 既然不使用循环或者递归,那我可要抖机灵了 如果某个数n为3的幂 ,则k=l ...

  10. ng-book札记——表单

    Angular表单的基本对象为FormControl与FormGroup. FormControl FormControl代表单个input表单字段(field),即Angular表单的最小单元. F ...