入职新公司,这边打算采用RN来写界面,所以学习一波这一块的知识。

  采用的是WebStorm来编译,据同事说,比他采用atom编译要多很多语法提示。
  下载地址:https://www.jetbrains.com/webstorm/
  安装之后需要破解:http://blog.csdn.net/zhalcie2011/article/details/57409082
  进入WebStorm,进行基础配置,诸如RN语法高亮等:http://blog.csdn.net/xiangzhihong8/article/details/52293896
  语法提示插件:https://github.com/virtoolswebplayer/ReactNative-LiveTemplate
  配置完成之后,RN相关Api、关键字等都有提示,算是比较友好了。

  RN项目基础配置    

import React, {Component} from 'react';

import
{
AppRegistry,
StyleSheet,
Text,
View
} from 'react-native';

import与iOS一致,是导入组件or面向组件,其中默认组件是不需要{}包裹起来的,比如说React,但是Component、Appregistry、Text等组件都是非默认组件,所以需要用{}包裹起来。

class MyApp extends Component {
render() {
var str = 'ppppppppppppppp';
return ( <View style={{backgroundColor: 'red', flex: 1}}>
<Text style={{flex: 1}}>{str}</Text>
</View>
)
}
}

上面的代码是自定义程序入口组件,类似于[[UIView alloc] init],当一个组件要显示的时候,就会自动调用render方法,渲染组件。extends关键字意味着继承自哪个类,这是ES6的语法,建议在看RN具体代码时,过一遍JS与ES6的语法。

我在学习的时候,有一点总是弄不清楚,不知道什么时候要加{},什么时候不加;也不知道什么时候加(),什么时候不加?

  1、包装对象的时候使用{},在JS中,对象就是这么写的 {x: 100, y: 100, method: function() {} }

  2、表达式都需要使用{},在上述的代码中,<View style={}.....    这就是一个赋值表达式,所以需要一个{},那么为什么{}里面还有{}呢?{flex: 1}这是个对象了,所以需要{}包裹起来

  3、变量也需要用{}包裹起来,比如上面的<Text style={{flex: 1}}>{str}</Text>中str是个变量,所以包裹起来显示,如果不包裹,那么text就是直接显示str。

  4、在包裹组件标签的时候,必须使用(),上面return () 里面的代码,就是组件标签。

var styles = StyleSheet.create({
font: {
fontWeight: 'bold',
color: 'green',
fontSize: 14,
},
});

    上面是样式表、组件外观等配置。也可以直接像html那般,写在组件里面,例如:<View style={{backgroundColor: 'red', flex: 1}}>。

    

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

注册程序入口组件,注册哪个组件、程序启动的时候就会自动去加载注册组件。

第一个参数:模块名称,随意填,但是必须与iOS模块名称一致,负责会报找不到组件入口的错误,这里的模块名是'MyApp'

第二个参数:函数,箭头函数ES6的语法,需要返回组件类名。

(箭头函数:=> 左边:函数参数,右边:函数返回值)

在学习过程中,没有感觉到RN的布局有什么困难的地方,就不记录了,下次更新prop与state、传值等知识。

React Native编译器的配置以及基础知识的更多相关文章

  1. 《React Native 精解与实战》书籍连载「Node.js 简介与 React Native 开发环境配置」

    此文是我的出版书籍<React Native 精解与实战>连载分享,此书由机械工业出版社出版,书中详解了 React Native 框架底层原理.React Native 组件布局.组件与 ...

  2. 【RL-TCPnet网络教程】第25章 DHCP动态主机配置协议基础知识

    第25章      DHCP动态主机配置协议基础知识 本章节为大家讲解DHCP(Dynamic Host Configuration Protocol,动态主机配置协议),通过前面章节对TCP和UDP ...

  3. Mac电脑配置IOS React Native开发环境配置笔记

    React Native(以下简称RN)的开发环境配置直接参考官方文档即可完成,不过对小白来说东西有点多,有些名词不是很好理解,这里就官方的安装文档稍微展开说一下. 中文版配置说明:不错的中文说明.官 ...

  4. windows 下android react native详细安装配置过程

    写在前面: 在网上搜了很多安装配置文档,感觉没有一个真的跟我安装的过程一模一样的,东拼拼西凑凑,总算是装好了,我不会告诉你,断断续续,我花了两天时间...一到黑屏报错就傻眼,幸好在react群里遇到了 ...

  5. 深入浅出React Native 1: 环境配置

    该教程主要介绍如何用react native来开发iOS,所以首先,你需要有一台mac,当然黑苹果也是可以的~ 创建一个react native的项目只需要安装以下五个组件~~(但....坑爹的是,不 ...

  6. LAMP配置课程基础知识详解

    听了一天的课程,我本人对这个还是很感兴趣的. [root@localhost~]#     root 用户名 localhost 本地 ~  家目录 不同用户不同 #当前用户是管理员 $当前用户是普通 ...

  7. React Native环境配置和简单使用

    # 前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会 ...

  8. Webstorm配置运行React Native

    Webstorm配置运行React Native 1.选择配置 2.选择npm,设置package等参数 3.添加拓展工具 4.配置拓展工具(核心啊) 5.运行测试,ok的.

  9. React Native iOS环境搭建

    前段时间React Native for Android发布,感觉React Native会越来越多的公司开始研究.使用.所以周六也抽空搭建了iOS的开发环境,以便以后利用空闲的时间能够学习一下. 废 ...

随机推荐

  1. cpio用法详细说明

    1.1 cpio基本介绍 cpio是一个非常古老的归档工具.已逐渐被tar替代,但是有些功能是tar不存在的,所以还是分享下它的用法. cpio - copy files to and from ar ...

  2. 《基于Node.js实现简易聊天室系列之详细设计》

    一个完整的项目基本分为三个部分:前端.后台和数据库.依照软件工程的理论知识,应该依次按照以下几个步骤:需求分析.概要设计.详细设计.编码.测试等.由于缺乏相关知识的储备,导致这个Demo系列的文章层次 ...

  3. Linux系统vi模式下显示行号

    在命令模式下输入:set nu或者:set number都可以为vi设置行号,如果要取消的话,则输入:set nonu行号的设置是vi的环境设置,不会影响文本的内容.

  4. php中memcache的运用

    <?php /** * •Memcache::add — 增加一个条目到缓存服务器 * •Memcache::addServer — 向连接池中添加一个memcache服务器 * •Memcac ...

  5. 【LeetCode】187. Repeated DNA Sequences

    题目: All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: " ...

  6. VB6之WebBrowser控件

    UI短手或者GDI+用烦的童鞋可以借用WebBrowser打造漂亮的程序界面,只需要下载一个好看点的html代码就够了. 引用: Microsoft Html Object Library 部件: M ...

  7. 如何使用SVN?

      一.什么是SVN? SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统,它的设计目标就是取代CVS.互联网上很多版本控制服务已从CVS迁 ...

  8. HDU 1325,POJ 1308 Is It A Tree

    HDU认为1>2,3>2不是树,POJ认为是,而Virtual Judge上引用的是POJ数据这就是唯一的区别....(因为这个瞎折腾了半天) 此题因为是为了熟悉并查集而刷,其实想了下其实 ...

  9. EventBus 事件总线之我的理解

    用例:假设公司发布了一个公告 需要通过短信 和 邮件分别2种方式 通知员工 1:首先我们建立领域模型 /// <summary> /// 领域核心基类 /// </summary&g ...

  10. Android事件分发理解

    Android事件分发机制是个难点和重点,结合下各家,写点自己的理解.. 首先抛出一个小问题,写一个button的点击事件 button.setOnClickListener(new OnClickL ...