- react-native flatlist 下拉刷新组件
- React Native在Android当中实践(二)——搭建开
- React Native在Android当中实践(三)——集成到
- React Native在Android当中实践(四)——代码集
- React Native在Android当中实践(五)——常见问
- React Native在Android当中实践(一)——背景介
- React Native 打包APK
- 从Android到React Native开发(四、打包流程解析
- 从Android到React Native开发(三、自定义原生控
- 从Android到React Native开发(二、通信与模块实
前言
React Native
有点大势所趋,所以前段时间研究了下它,看了它的官方文档同时也在Github
浏览了前辈们的杰作,所以自己也写了一个简单的Demo
也算是一个好的入门。配合官方文档与代码实例相信都能很快的进入React Native
的世界。下面我介绍的不会很详细,是针对React Native
语法有一定会基础的同学。
React Native介绍
这里简单的介绍下React Native
- 它是借助于
FaceBook
现有的轮子,它可以实现对ISO
和Android
两大平台的支持 - 使用
React.js
来操作原生的UI
组件,替代了DOM
元素 - 在
UI
方面,提供了Flexbox
的布局,同时也支持css-layout
样式 - 使用
JSX
来转换成JS
来执行,JSX
是一种类似于XML
语法的脚步扩展语言。
对于React Native
的环境搭建,可以参考官方文档Getting Started,如果英文不好的别急,这里还有中文版的Getting Started
推荐使用英文版的,中文版的还是存在坑,下面简单的介绍下Demo中用到的组件
Navigator
这是一个导航器,直白的理解就是实现界面之间的跳转,在React Native
中借助它能很好的实现界面的切换。实现它需要实现几个必要的方法。
<Navigator initialRoute={{title: '主页', component: Welcome}}
configureScene={(route,routeStack) => Navigator.SceneConfigs.FloatFromLeft}
renderScene={this.renderScene}/>
initialRoute
Navigator
都是由route
来控制跳转路线的,所以开始使用时要初始化route
initialRoute={{title: '主页', component: Welcome}}
里面的参数名不受限制,但是你必须要指明跳转的Componnet
组件名,方便在后续执行中取出。可以通过route.component
取出。
renderScene
该配置就是执行没一个route
的具体实现,从而渲染出来,它提供两个内置参数route
与navigator
,来方便渲染
renderScene={this.renderScene}
renderScene(route, navigator){
_navigator = navigator;
let DefaultComponet = route.component;
return <DefaultComponet
route = {route} navigator = {navigator}/>
}
在renderScene
中我们取出每次要导航的Component
,同时渲染出来,并且把route
与navigator
传到渲染的界面中。在渲染界面可以通过this.props.rout
与this.props.navigator
来获取。最后一步就是要绑定事件
this.renderScene = this.renderScene.bind(this);
不懂props的可以自己查阅官方文档
push与pop
Navigator
提供了push
与pop
方法来控制route
的路线,相当于我们熟知的栈。通过push
来设置下一个导航的route
,通过pop
来退出该界面返回原来的界面。
<TouchableOpacity onPress={() => this.props.navigator.push({
title: '详情',
component: Detail,
number: rowID,
})}>
<View style={styles.item}>
<View style={styles.content}>
<Text style={styles.des}>
{rowData.title}
</Text>
....
</View>
</TouchableOpacity>
TouchableOpacity
是一个点击监听组件,可以绑定点击事件。
<TouchableOpacity onPress={() => this.props.navigator.pop()}>
<Image source={require('../imgs/back.png')} style={styles.back}/>
</TouchableOpacity>
在点击以后渲染出来的界面中调用pop
方法退出该渲染.
ListView
是不是感觉很亲切,它要实现的功能跟Android
中是一样的。但是使用方法就不同了哦。不过整体需要的数据原理还是类似。无非也要整个的数据源,与绑定没个Item
的数据。
rowHasChanged
在渲染之前要设置判断该数据是否需要从新渲染,这样就减少许多不必要的渲染步骤,该方法能帮助我们进行判断。
const listView = new ListView.DataSource({
rowHasChanged: (r1,r2) => r1!==r2});
cloneWithRows
为listView
初始化数据源,可以通过state
状态来进行保存。
this.state={
dataSource: listView.cloneWithRows(this._rowData())};
}
绑定
最后在渲染render()
生命周期方法中进行组件资源绑定:
<ListView
style={styles.container}
dataSource={this.state.dataSource}
renderRow={this._renderRow.bind(this)}/>
</View>
其中dataSource
与renderRow
是两个必要的方法,前一个是绑定数据源,后一个是绑定渲染的每一行的数据。其中_renderRow
是Item
的布局。
_renderRow(rowData,sectionID,rowID,highlightRow){
return(
<TouchableOpacity onPress={() => this.props.navigator.push({
title: '详情',
component: Detail,
number: rowID,
})}>
<View style={styles.item}>
<View style={styles.content}>
<Text style={styles.des}>
{rowData.title}
</Text>
<View style={styles.bottom}>
<Text style={styles.fb}>
{"发布: "+rowData.fb}
</Text>
<Text style={styles.data}>
{"日期: "+rowData.data}
</Text>
</View>
</View>
<Image style={styles.image}
source={{uri: rowData.image}}/>
</View>
</TouchableOpacity>
);
}
renderRow
提供了四个参数rowData,sectionID,rowID,highlightRow
这里主要是利用rowData
来获取数据源。布局样式是使用css-layout
来实现,可以直接在组件是使用
style={{flex: 1}}
或者通过StyleSheet
来统一创建:
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#F5FCFF',
},
title: {
backgroundColor: 'royalblue',
justifyContent: 'center',
alignItems: 'center',
borderColor: 'gray',
borderBottomWidth: 1,
},
...
});
css这里不多说,自己可以参考官方文档
TabNavigator
这里再简单介绍下TabNavigator
这是一个类似于Android
中的FragmentTabHost
。相信都知道它的功能是什么了。
<TabNavigator>
<TabNavigator.Item
title="新闻"
selected={this.state.selectedTab==='news'}
selectedTitleStyle={styles.selectedText}
titleStyle={styles.text}
renderIcon={() => <Image source={require('../imgs/ic_news.png')} style={styles.image}/>}
renderSelectedIcon={() => <Image source={require('../imgs/ic_news_pressed.png')} style={styles.image}/>}
onPress={() => this.setState({selectedTab: 'news'})}>
<News {...this.props}/>
</TabNavigator.Item>
...
</TabNavigator>
通过<TabNavigator.Item>
子标签来设置每一个底部Item
,在其中在设置该Item
要渲染的界面,上面的News
就是要渲染的界面,该界面可以通过export default News
导出,import News from './News'
导入。
先就介绍到这里,如果还有需要可以下载源码,后续还会继续再做扩展
效果图
效果图项目地址:https://github.com/idisfkj/RNDemo
网友评论