一、ReactNavigation中如何实现页面跳转

因为每个屏幕组件(具有路由地址的组件)都是由App根组件自动创建并挂载的,App组件

在创建屏幕组件时,会自动传递进来一个props:   navigation

从当前屏幕跳转到其他屏幕:

this.props.navigation.navigate('屏幕地址')

注意:默认情况下,Image没有onPress事件,如果想要被点击实现跳转,

需要封装到"触摸反馈组件",如

<TouchableOpacity  onPress={  }>

<Image/>

</TouchableOpacity>

二、ReactNavigation中如何实现跳转传参

回忆:基于浏览器的Web应用中如何传参?

Angular中:

路由词典:{path:'product/detail/:pid',component:.... }

执行跳转:<a routerLink="product/details/">

注意:RN应用根本没有浏览器,没有地址栏,没有/15!

RN中的路由传参不需要修改路由词典:

     前一个组件跳转时提供路由参数:

this.props.navigation.navigate('目标地址',{pid:13,age:30})

后一个组件加载完成时读取路由参数:

this.props.navigation.state.params   ------------   { pid:13,age:30 }

或者

this.props.navigation.getParam( 'pid' , 99)              //99表示默认参数值

class  App extends  React.Component{

render(){

return (

<View>

<ScreenHeader>

{读取LoginScreen.navigationOptions来填充页头 }

</ScreenHeader>

<ContentOutlet>

{

if(当前客户端想访问login地址的话){

return  <LoginScreen  navigation={...}/>

}

}

</ContentOutlet>

</View>

)

}

}

三、ReactNavigation中如何配置页头

①仅指定标题栏文字

static   navigationOptions = {

         title: ' 标题栏文字 '

            }

②指定复杂的标题栏组件

static    navigationOptions ={

  headerTitle:<Any/>

                    headerLeft:<Any/>

                    headerRight:<Any/>

}

可以为headerTitle、headerLeft、headerRight属性赋值为任意组件/自定义组件,实现页头

自定义的功能;

此外,如果需要在页头中使用navigation对象,不能直接使用this.props.navigation(静态成员中

不能使用this),可以使用

static  navigationOptions =((obj)={

return {

   title:'商品编号:'  +obj.navigation.getParam('pid') +'的详情'

}

})

四、前端可用的异步请求技术有哪些?

①原生XHR:直接,但可能产生回调地狱

②jQuery.ajax():简单,但可能产生回调地狱

③Axios:功能强大,基于Promise

④HttpClient:功能强大,基于观察者模式

----------------------------------------------------

⑤Fetch:W3C的新标准,有望取代XHR

RN应用中没有浏览器,没有原生XHR技术;但是RN底层根据W3C Fetch标准,

提供了一套完整的Fetch API.

FetchAPI的使用方法:

     发起GET请求:  

fetch(url).then((res)=>{

return   res.json()   //等待下载完全响应消息主体,解析为JS对象

}).then((body)=>{

//body就是响应主体

}).catch((err)=>{

})

 发起POST请求:

       let  options ={

methods:'POST',

headers:{},

body:'k=v&k=v'

}

fetch(url).then((res)=>{

return   res.json()   //等待下载完全响应消息主体,解析为JS对象

}).then((body)=>{

//body就是响应主体

}).catch((err)=>{

})

2.小知识:如何在海量的代码快速定位错误  ------  调试技巧?

增量调试:注释掉最新添加的功能,如果没有错误了,说明最新添加的代码有问题;

如果仍旧有错,说明错误存在于之前的代码中;继续注释掉此新增加的功能....

功能1:

功能2:

//功能3:

//功能4:

3.如何在RN中实现类似于Web中顶部/底部固定效果?

要点:

①父容器<View>必须设定height,获取设定高度占比flex

②ScrollView天然就会占用所有可用空间,故可省略flex

③固定在底部的元素只需要声明在ScrollView下方

4.RN中如何获取当前手机屏幕的尺寸?

import  {Dimensions}   from   'react-native'

获取屏幕的宽:Dimensions.get('screen').width

获取屏幕的高:Dimensions.get('screen').height

获取窗口的宽:Dimensions.get('window').width

获取窗口的高:Dimensions.get('window').height

提示:手机中window的宽和screen的宽;screen的高等于window

的高+状态栏的高度.

ReactNavigation中如何实现页面跳转的更多相关文章

  1. PHP中常见的页面跳转方法

    转载自冠威博客 [ http://www.guanwei.org/ ]本文链接地址:http://www.guanwei.org/post/PHPnotes/04/php-redirect-metho ...

  2. Shiro中session超时页面跳转的处理

    问题描述 shiro在管理session后,在session超时会进行跳转,这里有两种情况需要考虑,一种是ajax方式的请求超时,一种页面跳转请求的超时. 本文从这两个方面分别考虑并处理. ajax请 ...

  3. java中自己对页面跳转问题的一些经验

    在eclipse中,如果你要在jsp页面跳转到servlet页面中,可以用action=“/根文件名/servlet文件名” 的方式跳转. 例如我创建了一个web application名字是test ...

  4. SpringMVC 04: SpringMVC中4种页面跳转方式

    转发和重定向的页面跳转方式 页面跳转方式,本质上只有2种方式:转发 + 重定向 但在SpringMVC的具体实现上,转发可以细分为:普通的页面转发 + 经由action方法的页面转发 重定向可以细分为 ...

  5. Nginx 使用自签名证书实现 https 反代 Spring Boot 中碰到的页面跳转问题

    问题一:页面自动跳转到 80 端口 问题描述 最近在使用Nginx反代一个Spring Boot项目中碰到了一个问题,使用 Spring Boot 中的 redirect: 进行页面跳转的时候,通过 ...

  6. 利用LI标签仿照a中Link进行页面跳转?

    点击LI时仿照A标签进行页面跳转html: <ul> <li link="/school/schooldetail/success_detail?case_id=<! ...

  7. ASP.NET MVC中如何实现页面跳转

    1,最简单的方式:超链接 以下分别是连接到HomeController控制器下的SharpL动作方法,以及百度首页.代码如下: <a href="Home\SharpL"&g ...

  8. 小程序中 wx.navigateTo 页面跳转没有反应?

    页面js文件中加入 show: function () {wx.navigateTo({url: ‘/pages/show/show’})} 这个函数 目的在于要做跳转到新的页面,但是你可能会遇到一个 ...

  9. jsp中的setHeader页面跳转备忘录

    1 <!-- response.setHeader("refresh","3;url=你想跳的页面")--> <%-- response.se ...

随机推荐

  1. 通达OA-2017版本漏洞复现

    搭建环境 服务器 虚拟机系统版本:Windows Server 2016. 安装服务端 1.下载安装程序 这里我们下载的是2017版本的通达OA服务端: 2.安装程序 配置服务: 漏洞复现 1.任意文 ...

  2. jQuery动态时钟

    效果图: 引用的jQuery.js自己百度 代码: <!DOCTYPE html> <html> <head> <meta charset="utf ...

  3. 【DNS域名解析命令】 dig

    dig - DNS lookup utility dig 命令主要用来从 DNS 域名服务器查询主机地址信息. Dig (domain information groper 域名信息搜索)是一个灵活的 ...

  4. 几个加速Swift开发的小tip

    又是周五了,周末不要浪,一起学点Swift!本周再次为大家带来了一些Swift的小技巧,都是些奇淫巧计,不知道也无妨,但Swift最吸引我的一点就是它的简洁易用.主要内容有: private(set) ...

  5. Android多线程下载远程图片

    修改后的代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 ...

  6. HR问了我朋友什么是简单工厂模式,竟被质疑是否学过设计模式,是否是计算机专业?

    越是简单的东西,越是容易被忽略,我来带你们好复习一下! 简单工厂模式 简单工厂模式也被称为静态工厂模式;使用简单工厂模式可以将产品的"消费"和生产完全分开,客户端只需要知道自己需要 ...

  7. STL训练 HDU - 1716 Ray又对数字的列产生了兴趣:

    HDU - 1716 Ray又对数字的列产生了兴趣: 现有四张卡片,用这四张卡片能排列出很多不同的4位数,要求按从小到大的顺序输出这些4位数. Input 每组数据占一行,代表四张卡片上的数字(0&l ...

  8. E. Yet Another Task with Queens(分类思想)

    \(\color{Red}{描述}\) \(在n*n的棋盘上有m个K皇后,每个皇后可能被来自8个方向的其他皇后攻击\) \(每个皇后只可能被(0-8)只皇后攻击,分别求出被(0-8)只皇后攻击的皇后数 ...

  9. 【学习笔记】Shell-1 变量:命名规范、变量赋值/取值/取消、局部变量/全局变量、预设环境变量

    1.Shell变量 从变量的实质上来说,变量名是指向一片用于存储数据的内存空间. Shell变量是一种弱类型的变量,即声明变量时不需要指定其变量类型,也不需求遵循“先声明再使用”的规定,想用即可用. ...

  10. Spring官网阅读(十三)ApplicationContext详解(下)

    文章目录 BeanFactory 接口定义 继承关系 接口功能 1.HierarchicalBeanFactory 2.ListableBeanFactory 3.AutowireCapableBea ...