一、react native中很多是ES6语法。
1行。表示是js的严格模式。
'use strict’;
严格模式中变量必须先声明,然后赋值、定义等;
还有就是this的绑定。
2行到8行。导入依赖,可以理解为java中import XX.react-native.React;和import XX.react-native.React.AppRegistry;这种。
9行。自定义组件,组件是React Native的基本元素,可以类比Activity。
10行到24行。render()方法,我的理解是渲染页面用的,里边的xml和layout类似,都是用来布局的。
26行到43行。通过StyleSheet.create()方法,生成布局所需的属性集合。在render()中的<View/>等添加style属性就可以了。类比android中每个View的属性,都是通过style来实现,我们创建的属性集合便是style集合。
44行。注册自定义组件。
二、react native中的点击事件一般用的是Touchable组件
其中常用的是TouchableHighlight 与TouchableOpacity
TouchableHighlight 是背景透明度的变化
TouchableOpacity 文本或图片自身的透明度变化
注意:Touchable 组件系列都只能包含一个子组件,也就是说你想多个,可以嵌套View组件来实现。如:
<TouchableHighlight > <View> <Text> t1 </Text> <Text> t2 </Text> </View> </TouchableHighlight>
三、页面跳转
首先要进行页面跳转控制器的配置,如下:
render() { return ( <Navigator initialRoute={{id: 'Page'}} renderScene={this.actionTo}/> ); }, actionTo(route, navigator){ switch (route.id) { case 'Page': return (<Page navigator={navigator}/>); case 'Page2': return (<Page2 navigator={navigator}/>); } }
Navigator就是页面跳转控制器,initialRoute指的是初始页面,renderScene是页面跳转时回调的方法,这里就是actionTo方法。
actionTo方法,便是通过route的属性,来跳转不同的页面,可以这样理解。
接下来需要页面跳转时,调用如下方法即可
this.props.navigator.push({ id: 'Page2', });
页面跳转主要代码:
let defaultComponent = TabBar; return ( <Navigator initialRoute={{ component: defaultComponent }} configureScene={(route) => { return Navigator.SceneConfigs.FloatFromRight; }} renderScene={(route, navigator) => { let Component = route.component; return <Component {...route.params} navigator={navigator} /> // 上面的route.params 是为了方便后续界面间传递参数用的 }} />
跳转的参考网址:https://github.com/yongqianvip/RN-ListViewLoadMore/blob/master/app/components/ProductImageShow.js