React Native——第一个示例
使用下面的命令 $ npm install -g react-native-cli
$ react-native init AwesomeProject
生成一个名为AwesomeProject的项目,输入 $ cd AwesomeProject/
$ react-native run-android
可以让项目工程运行起来。通过修改 显示本地数据在文件开头 var MOCKED_MOVIES_DATA = [
{title: 'Title',year: '2015',posters: {thumbnail: 'http://i.imgur.com/UePbdph.jpg'}},];
这里定义了一个数据,包括标题、日期和缩略图地址。 控件声明在 var { AppRegistry,Image,StyleSheet,Text,View,} = React;
显示图片用Image,文字用Text 页面显示逻辑在render函数里 render: function() { var movie = MOCKED_MOVIES_DATA[0]; return ( <View style={styles.container}> <Text>{movie.title}</Text> <Text>{movie.year}</Text> <Image source={{uri: movie.posters.thumbnail}} style={styles.thumbnail} /> </View> ); }
var styles = StyleSheet.create({ container: { flex: 1,justifyContent: 'center',alignItems: 'center',backgroundColor: '#F5FCFF',},thumbnail: { width: 53,height: 81,});
改变布局var styles = StyleSheet.create({ container: { flex: 1,flexDirection: 'row',rightContainer: { flex: 1,title: { fontSize: 20,marginBottom: 8,textAlign: 'center',year: { textAlign: 'center',});
其中 布局参数应用到布局中 render: function() { var movie = MOCKED_MOVIES_DATA[0]; return ( <View style={styles.container}> <Image source={{uri: movie.posters.thumbnail}} style={styles.thumbnail} /> <View style={styles.rightContainer}> <Text style={styles.title}>{movie.title}</Text> <Text style={styles.year}>{movie.year}</Text> </View> </View> ); },
重新加载显示如下 加载网络数据数据来源 var REQUEST_URL = 'https://raw.githubusercontent.com/facebook/react-native/master/docs/MoviesExample.json';
添加到文件开头 初始化数据定义在getInitialState中,我们会把网络请求的数据保存在movies变量中 getInitialState: function() {
return {
movies: null,};
},
componentDidMount: function() {
this.fetchData();
},fetchData: function() {
fetch(REQUEST_URL)
.then((response) => response.json()) .then((responseData) => { this.setState({ movies: responseData.movies,}); }) .done(); },
在网络数据返回之前显示loading页面,数据返回后再具体显示,可以通过判断movies的状态来显示具体的内容 render: function() { if (!this.state.movies) { return this.renderLoadingView(); } var movie = this.state.movies[0]; return this.renderMovie(movie); },renderLoadingView: function() { return ( <View style={styles.container}> <Text> Loading movies... </Text> </View> ); },renderMovie: function(movie) { return ( <View style={styles.container}> <Image source={{uri: movie.posters.thumbnail}} style={styles.thumbnail} /> <View style={styles.rightContainer}> <Text style={styles.title}>{movie.title}</Text> <Text style={styles.year}>{movie.year}</Text> </View> </View> ); },
ListView当数据是重复多条时,我们需要用ListView显示。添加ListView的声明 var { AppRegistry,ListView,} = React;
添加布局参数 listView: { paddingTop: 20,},
修改布局 render: function() {
if (!this.state.loaded) {
return this.renderLoadingView();
}
return (
<ListView
dataSource={this.state.dataSource}
renderRow={this.renderMovie}
style={styles.listView}
/>
);
},
getInitialState: function() {
return {
dataSource: new ListView.DataSource({
rowHasChanged: (row1,row2) => row1 !== row2,}),loaded: false,
修改数据请求 fetchData: function() {
fetch(REQUEST_URL)
.then((response) => response.json()) .then((responseData) => { this.setState({ dataSource: this.state.dataSource.cloneWithRows(responseData.movies),loaded: true,
最终的运行结果 Done. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- unexpectedly found nil while unwrapping an Optional val
- [寒江孤叶丶的Cocos2d-x之旅_25]Cocos2d-x 浅谈Lua与C++函数
- 【转载】XML
- ruby-on-rails – 具有块的Array.count不会返回正确的答案
- 跨平台APP----对Native/Hybrid/Web APP三种开发模式的分析(
- chromium之资源文件
- ruby-on-rails – Rails服务器错误:Ruby版本是1.8.7,但是你
- 记一次mariadb数据库无法连接
- C++ string类库简介
- 如何从datetime列中选择不同的年份并将结果添加到C#中的com