一、问题背景:

react native的跨平台开发没有button的概念,而是使用touchable系列实现点击触发效果。

而touchable系列就有四个之多,而且相互之间仍有较大差别,这就给我们造成很大的困扰,今天就来分析一下这类在react native中必不可少的组件。

二、分析描述

(一)、归类分析

  一共有四个touchable相关的点击触发按钮,分别是:

  • TouchableWithoutFeedback
  • TouchableOpacity
  • TouchableHighlight
  • TouchableNativeFeedback

   我们可以分成3类来描述:

  1. 第一类:TouchableWithoutFeedback: 触摸后在视觉上没有任何点击效果反馈
  2. 第二类:包括:TouchableHighlight 和 TouchableOpacity 两者都继承之TouchableWithoutFeedback
    • TouchableHighlight : 实现高亮的触摸反馈
    • TouchableOpacity   : 实现透明度的触摸反馈
  3. 第三类:TouchableNativeFeedback: 可以在Android 5.0以后触摸实现水波纹的效果,(因此仅限Android平台,iOS平台使用会报错)

(二)、详细描述

TouchableWithoutFeedback:

Touchable系列组件中最基本的一个组价,只响应用户的点击事件不会做任何UI上的改变,在使用的过程中需要特别留意。

注意:该标签不可以添加style样式属性,加了也没效果

相关属性:

  • onPress function   当触摸操作结束时调用,但如果被取消了则不调用(譬如响应者被一个滚动操作取代)
  • onLongPress function  当用户长时间按压组件(长按效果)的时候调用该方法。
  • disabled bool  如果设为true,则禁止此组件的一切交互。
  • onPressIn function与onPressOut function  分别是当用户开始点击按钮时与点击结束后被回调。
<TouchableWithoutFeedback
onPress={()=> {alert('触摸效果')}}
onLongPress={()=> {alert('长按效果')}}
disabled={false} //默认是false,如果是true表示关闭该组件的触摸功能
onPressIn={()=> {alert('触摸开始')}}
onPressOut={()=>{alert('触摸结束')}}
>
<View><Text>TouchableWithoutFeedback的测试</Text></View>
</TouchableWithoutFeedback>

TouchableHighlight:

Touchable系列组件中比较常用的一个,它是在TouchableWithoutFeedback的基础上添加了一些UI上的扩展,既当手指按下的时候,该视图的不透明度会降低,同时会看到相应的颜色(视图变暗或者变亮)

注意:该标签可以添加style样式属性,因为有一层<View>可以使用

其实就是在TouchableHighlight 的外层套了一层<View>通过改变view组件的颜色和透明度来实现点击效果的改变

相关属性:

  • activeOpacity number  用于设置被按下时按钮的不透明度,默认是0.85
  • underlayColor color  用于设置被按下时按钮的颜色,默认是black
  • onShowUnderlay function  最外层的View显示的时候调用
  • onHideUnderlay function  最外层的View被隐藏的时候调用
  • style View#style  最外层的View可以设置样式
  • onPress function   当触摸操作结束时调用,但如果被取消了则不调用(譬如响应者被一个滚动操作取代)
  • onLongPress function  当用户长时间按压组件(长按效果)的时候调用该方法。
  • disabled bool  如果设为true,则禁止此组件的一切交互。
  • onPressIn function与onPressOut function  分别是当用户开始点击按钮时与点击结束后被回调。
<TouchableHighlight
style={{}}
activeOpacity={0.6}
underlayColor='red'
onHideUnderlay={()=>{alert('衬底被隐藏')}}
onShowUnderlay={()=>{alert('衬底显示')}}
>
<View><Text>TouchableHighlight的测试</Text></View>
</TouchableHighlight>

TouchableOpacity:(完全同TouchableHighlight,只是不可以修改颜色,只能修改透明度,可以添加样式效果

TouchableOpacity也是Touchable系列组件中比较常用的一个,它是在TouchableWithoutFeedback的基础上添加了一些UI上的扩展,但这些扩展相比TouchableHighlight 少了一个额外的颜色变化。它是通过在按下去改变视图的不透明度来表示按钮被点击的。

TouchableNativeFeedback:(仅限Android平台,且5.0以上)

为了支持Android5.0新增的触控反馈,React Native加入了TouchableNativeFeedback 组件,TouchableNativeFeedback TouchableWithoutFeedback 所支持的属性的基础上增加了按下去的水波纹效果。我们可以通过background 属性来自定义原生触摸操作反馈的背景

(三)、补充提示

提示一:无论是TouchableWithoutFeedback还是其他三种Touchable组件,都是在根节点都是只支持一个组件,如果你需要多个组件同时响应单击事件,可以用一个View将它们包裹着,它的这种根节点只支持一个组件的特性和ScrollView很类似。

//错误示范:其他的Touchable系列同样
<TouchableHighlight
style={{}}
onPress={() => {alert('123')}}
>
<View><Text>TouchableHighlight的测试</Text></View>
<View><Text>这是错误的,TouchableHighlight中只能有一个总节点包裹</Text></View>
</TouchableHighlight> //正确
<TouchableHighlight
style={{}}
onPress={() => {alert('123')}}
>
<View>
<View><Text>TouchableHighlight的测试</Text></View>
<View><Text>这是错误的,TouchableHighlight中只能有一个总节点包裹</Text></View>
</View>
</TouchableHighlight>

提示二: <Text>组件也有点击功能 可通过onPress实现触摸回调

//Text也可以实现点击功能
<Text
style={{}}
onPress={()} => {alert('Text组件的点击功能')}
>Text的点击功能
</Text>

三、结束

react native 触摸Touchable***的区别(TouchableWithoutFeedback、TouchableOpacity、TouchableHighlight、TouchableNativeFeedback)的更多相关文章

  1. React Native 之 Touchable 介绍与使用

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  2. React Native中Touchable组件的使用

    截图如下: /** * Sample React Native App * https://github.com/facebook/react-native * @flow */ import Rea ...

  3. react native touchable

    <Button style={{marginTop: 30}} onPress={() => { Alert.alert("你点击了按钮!"); }} onPressI ...

  4. React Native组件(二)View组件解析

    相关文章 React Native探索系列 React Native组件系列 前言 了解了RN的组件的生命周期后,我们接着来学习RN的具体的组件.View组件是最基本的组件,也是首先要掌握的组件,这一 ...

  5. React Native 网络请求

    如下面的Code,分别介绍了GET,POST,以及使用XMLHttpRequest的Get请求. import React, { Component } from 'react'; import { ...

  6. React Native交互组件之Touchable

    React Native交互组件之Touchable:只要在组件外面包一个Touchable组件就可以实现点击交互. TouchableHighlight:高亮触摸 当点击时,组件的透明度会改变,可以 ...

  7. 一起来点React Native——常用组件之Touchable系列

    在前面的登录界面中,我们发现所有的组件不会对用户的点击.触摸.拖拽做出合适的响应,这是十分不友好的.那么,在React Native中如何让视图对触发做出合适的响应呢? 一.高亮触摸  Touchab ...

  8. 从零学React Native之09可触摸组件

    可触摸组件有: TouchableHighlight,TouchableNativeFeedback,TouchableOpacity,TouchableWithoutFeedback 1. Touc ...

  9. 移动端学习之理解WEB APP、Native APP、Hybrid APP以及React Native/uniapp包括H5、小程序等的区别与共通之处

    因为工作需要,需要进一步了解移动端的开发,遂返回复习移动端的知识点,在开始学习之前,产生了疑惑WEB APP .Native APP .Hybrid APP.React Native.Uniapp.H ...

随机推荐

  1. 如何在IDEA启动多个Spring Boot工程实例

    在我讲解的案例中,经常一个工程启动多个实例,分别占用不同的端口,有很多读者百思不得其解,在博客上留言,给我发邮件,加我微信询问.所以有必要在博客上记录下,方便读者. step 1 在IDEA上点击Ap ...

  2. python中的运算符优先级(其它语言也试用)

  3. 【spring源码学习】Spring @PostConstruct和@PreDestroy实例

    在Spring中,既可以实现InitializingBean和DisposableBean接口或在bean配置文件中指定 init-method 和 destroy-method 在初始化和销毁回调函 ...

  4. Eclipse设置Courier New字体

    使用Eclipse我们会发现在字体设置里找不到钟爱的Courier New字体.其实这个字体不是没有,只是没有显示而已,它其实隐藏起来了,只需几步便可让其现原形—— 1.找到Eclipse设置字体的地 ...

  5. Quick guide for converting from JAGS or BUGS to NIMBLE

    Converting to NIMBLE from JAGS, OpenBUGS or WinBUGS NIMBLE is a hierarchical modeling package that u ...

  6. 汇编_指令_IRET

    IRET(interrupt return)中断返回,中断服务程序的最后一条指令.   汇编指令IRET [指令格式]IRET   [指令功能]IRET(interrupt return)中断返回,中 ...

  7. codeforce1029B B. Creating the Contest(简单dp,简单版单调栈)

    B. Creating the Contest time limit per test 1 second memory limit per test 256 megabytes input stand ...

  8. 关于mysql 间隙锁

    前段时间系统老是出现update死锁,很是纠结.经过排查发现是间隙锁!间隙锁是innodb中行锁的一种, 但是这种锁锁住的却不止一行数据,他锁住的是多行,是一个数据范围.间隙锁的主要作用是为了防止出现 ...

  9. 学习了django对于sqlite3进行了了解,谈谈看法

    学习了django对于sqlite3进行了了解,谈谈看法 由于django默认使用的是sqlite3,写了几个建表语句, 然后数据做下迁移,其实就是建表语句的执行. 一直对sqlite3没有一个直观的 ...

  10. OpenCL 矢量存取

    ▶ 函数 vloadn 和 vstoren 来实现全局存储器和局部存储器之间的向量拷贝 ● 代码 #include <stdio.h> #include <stdlib.h> ...