React Native编译器的配置以及基础知识
入职新公司,这边打算采用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编译器的配置以及基础知识的更多相关文章
- 《React Native 精解与实战》书籍连载「Node.js 简介与 React Native 开发环境配置」
此文是我的出版书籍<React Native 精解与实战>连载分享,此书由机械工业出版社出版,书中详解了 React Native 框架底层原理.React Native 组件布局.组件与 ...
- 【RL-TCPnet网络教程】第25章 DHCP动态主机配置协议基础知识
第25章 DHCP动态主机配置协议基础知识 本章节为大家讲解DHCP(Dynamic Host Configuration Protocol,动态主机配置协议),通过前面章节对TCP和UDP ...
- Mac电脑配置IOS React Native开发环境配置笔记
React Native(以下简称RN)的开发环境配置直接参考官方文档即可完成,不过对小白来说东西有点多,有些名词不是很好理解,这里就官方的安装文档稍微展开说一下. 中文版配置说明:不错的中文说明.官 ...
- windows 下android react native详细安装配置过程
写在前面: 在网上搜了很多安装配置文档,感觉没有一个真的跟我安装的过程一模一样的,东拼拼西凑凑,总算是装好了,我不会告诉你,断断续续,我花了两天时间...一到黑屏报错就傻眼,幸好在react群里遇到了 ...
- 深入浅出React Native 1: 环境配置
该教程主要介绍如何用react native来开发iOS,所以首先,你需要有一台mac,当然黑苹果也是可以的~ 创建一个react native的项目只需要安装以下五个组件~~(但....坑爹的是,不 ...
- LAMP配置课程基础知识详解
听了一天的课程,我本人对这个还是很感兴趣的. [root@localhost~]# root 用户名 localhost 本地 ~ 家目录 不同用户不同 #当前用户是管理员 $当前用户是普通 ...
- React Native环境配置和简单使用
# 前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会 ...
- Webstorm配置运行React Native
Webstorm配置运行React Native 1.选择配置 2.选择npm,设置package等参数 3.添加拓展工具 4.配置拓展工具(核心啊) 5.运行测试,ok的.
- React Native iOS环境搭建
前段时间React Native for Android发布,感觉React Native会越来越多的公司开始研究.使用.所以周六也抽空搭建了iOS的开发环境,以便以后利用空闲的时间能够学习一下. 废 ...
随机推荐
- JAVA基础-JSON
/** * 1.根据接收到的JSON字符串来解析字符串中所包含的数据和数据对象 */ System.out.println("1.根据接收到的JSON字符串来解析字符串中所包含的数据和数据对 ...
- 保存Druid的监控记录
继上篇帖子之后 , 公司又要求将Druid Monitor的监控信息保存起来 , 因为Druid的监控记录在是缓存的,重启之后无法找回,所以需要做持久化,定期把监控记录转存到日志文件中 研究了半天 , ...
- Android 4.0以后正确的获取外部sd卡存储目录
刚解决这个棘手的问题 找了很久,随笔记下. 网上搜索 android 获取外部sd卡存储目录 普遍都是: 1) Environment.getExternalStorageDirectory() 这个 ...
- Example008关闭IE窗口时,不弹出询问对话框
<!-- 实例008关闭IE主窗口时,不弹出询问对话框 --> <meta charset="UTF-8"> <a href="#" ...
- Apollo框架试玩
2017年7月5日,百度举行了AI开发者大会,在会上发布了Apollo项目,并进行了演示,该项目在Github上已经能够被访问.出于一个程序员的好奇,昨天试玩了一把,确实不错. http://apol ...
- MyBatis源码解析【5】工厂的构建
前言 这个分类比较连续,如果这里看不懂,或者第一次看,请回顾之前的博客 http://www.cnblogs.com/linkstar/category/1027239.html 终于算是把装备弄齐全 ...
- (转载)Oracle10g 数据泵导出命令 expdp 使用总结(三)
原文链接:http://hi.baidu.com/edeed/item/19aa0df856da3e19a6298894 Oracle10g 数据泵导出命令 expdp 使用总结(一) 14. JOB ...
- CharacterEncodingFilter -处理字符格式
package com.pb.news.web.filter; import java.io.IOException;import javax.servlet.Filter;import javax. ...
- js-txt文本处理
js-txt文本处理 写自己主页项目时所产生的小问题拿出来给大家分享分享,以此共勉. ---DanlV TextArea的换行符处理 TextArea文本转换为Html:写入数据库时使用 js获取了t ...
- mysql中exists、not exists的用法
exists 关键字是判断是否存在的,存在则返回true,不存在则返回false, not exists则是不存在时返回true,存在返回false: 1. 最常用的if not exists用法: ...