React Native控件概述

1.控件介绍及分类
(1)基础组件
(2)第三方组件
(3)自定义组件
(4)统一样式风格,主题变换的组件
(5)元组件和复合组件
2.如何创建控件component
(1)ES6推荐 Component
(2)ES5使用 createReactClass
(3)通过函数创建组件 function
3.封装App使用的控件
4.参考文章

1.控件介绍及分类
(1)基础组件

View 基础视图
Text 文本展示
Button 按钮控件
Image 图片控件
TextInput 输入控件
FlatList 列表控件
ScrollView 滚动控件
RadioGroup 多选控件
RadioButton 单选控件
Switch 切换开关控件
ImageBackground 图片背景控件
Dialog 对话框
WebView 浏览器控件
Touchable 触摸控件

(2)第三方组件

图表报表 https://github.com/tomauty/react-native-chart
设备信息 https://github.com/react-native-community/react-native-device-info
抽屉效果 https://github.com/root-two/react-native-drawer
侧滑按钮 https://github.com/dancormier/react-native-swipeout
轮播视图 https://github.com/race604/react-native-viewpager
动画组件 https://github.com/oblador/react-native-animatable

(3)自定义组件

一种是Component的组合,View的叠加:
 class MyButton extends Component {
    render() {
        return (
<TouchableHighlight  
                       underlayColor={this.props.bgColor}
                       activeOpacity={0.5}
                       onPress={this.props.onPress} >
            <Image source={require('./res/himi.png')}
                style={ { width: 100, height: 100}}/>         
                 </TouchableHighlight>
        )
    }
}
另一种是 native和js的协议组合,Js和Native的结合

需要写三端的代码,js、android、ios。
其中name属性:js与native有相同的名字
支持的参数类型有:boolean, int, float, double, String, Boolean, Integer, ReadableArray, ReadableMap。
js端代码样例:

// ImageView.js
import { PropTypes } from 'react';
import { requireNativeComponent, View } from 'react-native';
var iface = {
  name: 'ImageView', //native端使用相同的参数
  propTypes: {
    src: PropTypes.string,    //native使用对应的参数
    borderRadius: PropTypes.number,   //native使用对应的参数
    resizeMode: PropTypes.oneOf(['cover', 'contain', 'stretch']),    //native使用对应的参数
    ...View.propTypes // 包含默认的View的属性
  },
};
module.exports = requireNativeComponent('RCTImageView', iface);

ios实现步骤:
首先创建一个子类
添加RCT_EXPORT_MODULE()标记宏
实现-(UIView *)view方法

android实现步骤 :
创建一个ViewManager的子类。
实现createViewInstance方法。
导出视图的属性设置器:使用@ReactProp(或@ReactPropGroup)注解。
把这个视图管理类注册到应用程序包的createViewManagers里。

(4)统一样式风格,主题变换的组件

如果准备开发一款设计风格统一的rn程序,并且可以轻松切换主题样式。美团的绿、京东的红、滴滴的橙等等等

(5)元组件和复合组件

元组件:框架内置的,可以直接使用的组件。例如:View、Image等。它在React Native中ReactNativeBaseComponent来描述。
复合组件:用户封装的组件,一般可以通过集成Component来构建,提供render()方法来返回渲染目标。它在React Native中用ReactCompositeComponent来描述。

2.如何创建控件component
(1)ES6推荐 Component

export default 的作用是导出该类,以供外面使用。

import React, { Component } from 'react';
import {
    StyleSheet,
    Text,
    View
} from 'react-native';
export default class MyComponent extends Component {
    render() {
        return <Text style={{fontSize:20,backgroundColor:'red'}}>Hello {this.props.name}</Text>
    }
}

(2)ES5使用 createReactClass

module.exports 的作用是导出该类,以供外面使用。

var MyComponent=React.createClass({
    render(){
        return <Text style={{fontSize:20,backgroundColor:'red'}}>Hello </Text>
    }
})
module.exports = MyComponent;

(3)通过函数创建组件 function

函数式(无状态,不能使用this)
module.exports 的作用是导出该类,以供外面使用。

function MyComponent(props) {
    return <Text style={{fontSize:20,backgroundColor:'red'}}>Hello {props.name}</Text>
}
module.exports = MyComponent;

3.封装App使用的控件:

XXLog 统一日志
XXLogin 登陆
XXNetwork 网络请求
XXShare 分享控件
XXRouter 路由跳转控件

4.参考文章
https://www.jianshu.com/p/c24173d5583d
https://segmentfault.com/a/1190000008402834
https://www.cnblogs.com/cag2050/p/9493138.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351