React-Native进阶_6.导航 Naviagtion传递数据并展示
接着上面 Navigation 继续学习传递数据给下一个页面
onPress={() => this.props.navigation.navigate('Detail',{info:movie.title,movie:movie})}
这样,跳转到详情页,可以传递 电影标题 movie.title 和电影对象 movie
在 MovieDetail 页面中 可以拿到这些数据
this.props.navigation.state.params.movie 就可以拿到  电影对象 movie
接下来拿到电影信息,再去请求数据,展示在电影详情页,这里展示一下电影简介
/**
 * 电影详情页
 */
'use strict'
import React, {Component} from 'react';
import styles from '../Styles/Main';
import {
    ActivityIndicator,
    Text,
    View,
} from 'react-native';
export  default class MovieDetail extends Component{
    constructor(props){
        super(props);
        this.state={
            movieDetail:'123',
            loaded:false,
        };
      const REQUEST_URL = `https://api.douban.com/v2/movie/subject/${this.props.navigation.state.params.movie.id}`;
      this._fetchData(REQUEST_URL);
    }
    _fetchData(REQUEST_URL){
        fetch(REQUEST_URL)
            .then(response => response.json())
            .then(responseData =>{
                this.setState({
                    movieDetail:responseData,
                    loaded:true,
                });
            })
            .done();
    }
    render() {
        if(!this.state.loaded){
            return this._renderLoadingView();
        }
        //   {summary}
        // The screen's current route is passed in to `props.navigation.state`: {params.movie.title}  this.state.movieDetail.summary  { this.setState.movieDetail}
      // const { params } = this.props.navigation.state
       // const { navigator} = this.props
        let movie = this.state.movieDetail;
        let summary = movie.summary.split(/\n/).map(p =>{
            return(
                <View style={ {marginBottom:15,paddingLeft:6,paddingRight:6}}>
                    <Text style={ styles.itemText} >{p}</Text>
                </View>
            )
        })
        return (
            <View  style ={styles.Container}>
                <View style ={[styles.item,{flexDirection:'column'}]}>
                    {summary}
                </View>
            </View>
        );
    }
    _renderLoadingView(){
        return (
            <View style ={styles.loading}>
                <ActivityIndicator
                    size = 'large'
                    color ='#6435c9'
                />
            </View>
        );
    };
}
UI展示:
React-Native进阶_6.导航 Naviagtion传递数据并展示的更多相关文章
- React Native原生模块向JS传递数据的几种方式(Android)
		
一般情况可以分为三种方式: 1. 通过回调函数Callbacks的方式 2. 通过Promises的异步的方式 3. 通过发送事件的事件监听的方式. 参考文档:传送门
 - React Native 系列(八) -- 导航
		
前言 本系列是基于React Native版本号0.44.3写的.我们都知道,一个App不可能只有一个不变的界面,而是通过多个界面间的跳转来呈现不同的内容.那么这篇文章将介绍RN中的导航. 导航 什么 ...
 - React-Native进阶_5.导航 Naviagtion
		
有这样一个组件 他可以控制页面跳转 返回,在移动端叫做导航控制器, 在RN中叫路由 我们使用的 react-native-navigation 是一个开源组件库介绍:A complete nativ ...
 - React Native中自定义导航条
		
这是2017年年初开始的公司的项目,对于导航条的要求很高,Android和iOS上必须用一致的UI,按钮位置还有各种颜色都有要求,而且要适应各种奇葩要求. 尝试了一下当时React Native自带的 ...
 - react native进阶
		
一.前沿||潜心修心,学无止尽.生活如此,coding亦然.本人鸟窝,一只正在求职的鸟.联系我可以直接微信:jkxx123321 二.项目总结 **||**文章参考资料:1. http://blog ...
 - React Native底|顶部导航使用小技巧
		
导航一直是App开发中比较重要的一个组件,ReactNative提供了两种导航组件供我们使用,分别是:NavigatorIOS和Navigator,但是前者只能用于iOS平台,后者在ReactNati ...
 - React Native顶|底部导航使用小技巧
		
导航一直是App开发中比较重要的一个组件,ReactNative提供了两种导航组件供我们使用,分别是:NavigatorIOS和Navigator,但是前者只能用于iOS平台,后者在ReactNati ...
 - react native之使用 Fetch进行网络数据请求
		
这是一个单独的页面,可以从其他地方跳转过来. 输入语言关键字,从github检索相关数据 import React, {Component} from 'react'; import { StyleS ...
 - React Native 学习笔记--进阶(二)--动画
		
React Native 进阶(二)–动画 动画 流畅.有意义的动画对于移动应用用户体验来说是非常必要的.我们可以联合使用两个互补的系统:用于全局的布局动画LayoutAnimation,和用于创建更 ...
 
随机推荐
- 注意:PHP7中十个需要避免的坑
			
1.不要使用mysql_函数 这一天终于来了,从此你不仅仅“不应该”使用mysql_函数.PHP7已经把它们从核心中全部移除了,也就是说你需要迁移到好得多的mysqli_函数,或者更灵活的PDO实现. ...
 - 2017年4月16日 一周AnswerOpenCV佳作赏析
			
2017年4月16日 一周AnswerOpenCV佳作赏析 1.HelloHow to smooth edge of text in binary image, based on threshold. ...
 - oppo R9 WLAN使用代理图解
			
以上拼图便是oppo R9 WLAN使用代理图解,代理设为 '手动' ,主机名便是我的电脑的ip地址,端口号是9973: + 9973端口号 (微信web开发者工具不可更改): + 8888 端口号 ...
 - terminal配置
			
阅读目录 前言 使用 tmux 复用控制台窗口 在命令行中快速移动光标 在命令行中快速删除文本 快速查看和搜索历史命令 快速引用和修饰历史命令 录制屏幕并转换为 gif 动画图片 总结 回到顶部 前言 ...
 - 如何使用openwrt下的分区表生成器ptgen
			
1.基本用法如下: ptgen [-v] -h <heads> -s <sectors> -o <outputfile> [-a 0..4] [-l <ali ...
 - HTML中的figure和gigcaption标签
			
参考自:anti-time的博客http://www.cnblogs.com/morning0529/p/4198494.html 在写xhtml.html中常常用到一种图片列表,图片+标题或者图片+ ...
 - sqlite的Top筛选
			
select [CollectDateTime] as '时间',[Channel_34] as '通道34',[Channel_54] as '通道54' from [DataTable] wher ...
 - ArrayBuffer
			
ArrayBuffer对象.TypedArray视图和DataView视图是 JavaScript 操作二进制数据的一个接口.这些对象早就存在,属于独立的规格(2011 年 2 月发布),ES6 将它 ...
 - 【性能测试】服务器性能监控、数据采集工具nmon安装使用详解
			
nmon nmon是一种在AIX与各种Linux操作系统上广泛使用的监控与分析工具,它能在系统运行过程中实时地捕捉系统资源的使用情况,并且能输出结果到文件中,然后通过nmon_analyzer工具产生 ...
 - poi 取excel单元格内容时,需要判断单元格的类型,才能正确取出
			
以下内容非原创,原文链接http://blog.sina.com.cn/s/blog_4b5bc01101015iuq.html ate String getCellValue(HSSFCell ce ...