【React Native开发】React Native控件之Touchable*系列组件详解(18)

转载请标明出处:

http://blog.csdn.net/developer_jiangqq/article/details/50630984

本文出自:【江清清的博客】

()前言

       【好消息】个人网站已经上线运行,后面博客以及技术干货等精彩文章会同步更新,请大家关注收藏:http://www.lcode.org      

      今天我们一起来看一下Touchable*系列组件的使用详解,该系列组件包括四种分别为:TouchableHighlight,TouchableNativeFeedback,TouchableOpacity,TouchableWithoutFeedback。其中最后一个控件是触摸点击不带反馈效果的,另外三个都是有反馈效果。可以这样理解前面三个都是继承自TouchableWithoutFeedback扩展而来。

      刚创建的React Native技术交流3群(496508742),react Native技术交流4群(458982758),请不要重复加群!欢迎各位大牛,ReactNative技术爱好者加入交流!同时博客左侧欢迎微信扫描关注订阅号,移动技术干货,精彩文章技术推送!

         今天我们需要讲解的这四种控件都是属于Touchable系列的,是封装了触摸点击相关事件,例如:触摸,点击,长按,反馈等相关。下面我们来把这四种组件分别进行讲解一下。

()TouchableWithoutFeedback

         2.1.TouchableWithoutFeedback组件基本介绍

          该控件除非你不得不使用,否则请不要使用该组件哦~任何可以响应事件的控件当触摸或者点击的时候应该会有视觉上面的反应效果(但是该组件没有)。这就是一个很大的原因,看起来像Web效果而不是原生的效果(Native)

【特别声明】TouchableWithFeedback只支持一个字节点,如果你需要设置多个子视图组件,那么就需要使用View节点进行包装。

          2.2.属性方法

  • accessibilityComponentType   View.AccessibilityComponentType  设置可访问的组件类型
  • accessibilityTraits View.AccessibilityTraits,[View.AccessibilityTraits设置访问特征
  • accessible  bool  设置当前组件是否可以访问
  • delayLongPress  number  设置延迟的时间,单位为毫秒。从onPressIn方法开始,到onLongPress被调用这一段时间
  • delayPressIn  number 设置延迟的时间,单位为毫秒,从用户触摸控件开始到onPressIn被调用这一段时间
  • delayPressOut  number 设置延迟的时间,单位为毫秒,从用户触摸事件释放开始到onPressOut被调用这一段时间
  • onLayout  function  当组件加载或者改组件的布局发生变化的时候调用。调用传入的参数为{nativeEvent:{layout:{x,y,width,height}}}
  • onLongPress function 方法,当用户长时间按压组件(长按效果)的时候调用该方法
  • onPress function 方法 当用户点击的时候调用(触摸结束) 但是如果事件被取消了就不会调用。(例如:当前被滑动事件所替代)
  • onPressIn  function  用户开始触摸组件回调方法
  • onPressOut function 用户完成触摸组件之后回调方法
  • pressRetentionOffset {top:number,left:number,bottom:number,right:number}   该设置当视图滚动禁用的情况下,可以定义当手指距离组件的距离。当大于该距离该组价会失去响应。当少于该距离的时候,该组件会重新进行响应。

该组件我们一般不会直接进行使用,下面三种Touchable*系列组件对于该组件的属性方法都可以进行使用。具体会具体演示这些属性方法的使用实例。

()TouchableHighlight(触摸点击高亮效果)

          3.1.TouchableHighlight组件基本介绍

           该组件进行封装视图触摸点击的属性。当手指点击按下的时候,该视图的不透明度会进行降低同时会看到相应的颜色(视图变暗或者变亮)。如果我们去查看该组件的源代码会发现,该底层实现是添加了一个新的视图。如果如果我们没有正确的使用,就可能不会出现正确的效果。例如:我们没有给该组件视图设置backgroudnColor的颜色值。

【特别声明】TouchableHighlight只支持一个子节点,如果你需要设置多个子视图组件,那么就需要使用View节点进行包装。

           3.2.属性方法

  • TouchableWithoutFeedback 属性,这边TouchableHighlight组件全部可以进行使用
  • activeOpacity  number 该用来设置视图在进行触摸的时候,要要显示的不透明度(通常在0-1之间)
  • onHideUnderlay  function  方法 当底层被隐藏的时候调用
  • onShowUnderlay  function 方法 当底层显示的时候调用
  • style  可以设置控件的风格演示,该风格演示可以参考View组件的style 
  • underlayColor  当触摸或者点击控件的时候显示出的颜色

3.3.组件使用实例代码

[html] view plain copy
  1. 'use strict';  
  2. import React, {  
  3.   AppRegistry,  
  4.   Component,  
  5.   StyleSheet,  
  6.   Text,  
  7.   View,  
  8.   TouchableHighlight,  
  9. } from'react-native';  
  10.    
  11. class TouchableHighlightDemo extends Component {  
  12.   render() {  
  13.     return (  
  14.       <View style={styles.container}>  
  15.         <Text >  
  16.           TouchableHighlight实例  
  17.         </Text>  
  18.         <TouchableHighlight  
  19.           underlayColor="rgb(210, 230,255)"  
  20.           activeOpacity={0.5}   
  21.           style={{ borderRadius: 8,padding:6,marginTop:5}}  
  22.           >  
  23.              <Text style={{fontSize:16}}>点击我</Text>  
  24.         </TouchableHighlight>  
  25.       </View>  
  26.     );  
  27.   }  
  28. }  
  29. const styles =StyleSheet.create({  
  30.   container: {  
  31.     flex: 1,  
  32.     justifyContent: 'center',  
  33.     alignItems: 'center',  
  34.     backgroundColor: '#F5FCFF',  
  35.   },  
  36. });  
  37. AppRegistry.registerComponent('TouchableHighlightDemo',() => TouchableHighlightDemo);  

         3.4.运行效果如下:

【React Native开发】React Native控件之Touchable*系列组件详解(18)

()TouchableOpacity(透明度变化)

          4.1.TouchableOpacity组件介绍

          该组件封装了响应触摸事件。当点击按下的时候,该组件的透明度会降低。该组件使用过程中并不会改变视图的层级关系,而且我们可以非常容易的添加到应用并且不会产生额外的异常错误。

         4.2.属性方法

  • TouchableWithoutFeedback 属性,这边TouchableOpacity组件全部可以进行使用
  • activeOpacity  number  设置当用户触摸的时候,组件的透明度

        4.3.组件使用实例代码:

[html] view plain copy
  1. 'use strict';  
  2. import React, {  
  3.   AppRegistry,  
  4.   Component,  
  5.   StyleSheet,  
  6.   Text,  
  7.   View,  
  8.   TouchableOpacity,  
  9. } from'react-native';  
  10.    
  11. class TouchableDemo extends Component {  
  12.   render() {  
  13.     return (  
  14.       <View style={styles.container}>  
  15.         <Text>  
  16.            TouchableOpacity实例  
  17.         </Text>  
  18.         <TouchableOpacity style={{marginTop:20}}>  
  19.            <Text style={{fontSize:16}}>点击改变透明度</Text>  
  20.         </TouchableOpacity>  
  21.       </View>  
  22.     );  
  23.   }  
  24. }  
  25. const styles =StyleSheet.create({  
  26.   container: {  
  27.     flex: 1,  
  28.     justifyContent: 'center',  
  29.     alignItems: 'center',  
  30.     backgroundColor: '#F5FCFF',  
  31.   },  
  32. });  
  33.    
  34. AppRegistry.registerComponent('TouchableDemo',() => TouchableDemo);  

           4.4.运行效果截图:

【React Native开发】React Native控件之Touchable*系列组件详解(18)

               4.5.实例演示onPress,onPressIn,onPressOut,onLongPress方法代码如下:

[html] view plain copy
  1. 'use strict';  
  2. import React, {  
  3.   AppRegistry,  
  4.   Component,  
  5.   StyleSheet,  
  6.   Text,  
  7.   View,  
  8.   TouchableOpacity,  
  9. } from'react-native';  
  10.    
  11. var TouchableDemo =React.createClass({  
  12.     getInitialState: function() {  
  13.     return {  
  14.       eventLog: [],  
  15.     };  
  16.   },  
  17.   render: function() {  
  18.     return (  
  19.       <View >  
  20.         <View style={[styles.row,{justifyContent: 'center'}]}>  
  21.           <TouchableOpacity  
  22.             style={styles.wrapper}  
  23.             onPress={() =>this._appendEvent('press')}  
  24.             onPressIn={() =>this._appendEvent('pressIn')}  
  25.             onPressOut={() =>this._appendEvent('pressOut')}  
  26.             onLongPress={() =>this._appendEvent('longPress')}>  
  27.             <Text style={styles.button}>  
  28.               Press Me  
  29.             </Text>  
  30.           </TouchableOpacity>  
  31.         </View>  
  32.         <View  style={styles.eventLogBox}>  
  33.           {this.state.eventLog.map((e, ii)=> <Text key={ii}>{e}</Text>)}  
  34.         </View>  
  35.       </View>  
  36.     );  
  37.   },  
  38.   _appendEvent: function(eventName) {  
  39.     var limit = 6;  
  40.     var eventLog = this.state.eventLog.slice(0,limit - 1);  
  41.     eventLog.unshift(eventName);  
  42.     this.setState({eventLog});  
  43.   },  
  44. });  
  45. const styles =StyleSheet.create({  
  46.   button: {  
  47.     color: '#007AFF',  
  48.   },  
  49.   wrapper: {  
  50.     borderRadius: 8,  
  51.   },  
  52.   eventLogBox: {  
  53.     padding: 10,  
  54.     margin: 10,  
  55.     height: 120,  
  56.     borderWidth: StyleSheet.hairlineWidth,  
  57.     borderColor: '#f0f0f0',  
  58.     backgroundColor: '#f9f9f9',  
  59.   },  
  60. });  
  61. AppRegistry.registerComponent('TouchableDemo',() => TouchableDemo);  

       4.6.运行效果截图:

【React Native开发】React Native控件之Touchable*系列组件详解(18)

()TouchableNativeFeedback

           5.1.TouchableNativeFeedback组件介绍

            该封装了可以进行响应触摸事件的组件(仅限Android平台)。在android平台上面该该组件可以使用原生平台的状态资源来显示触摸状态变化。【特别注意】现如今该组件只是支持仅有一个View的子视图实例(作为子节点)。在底层实现上面实际上面是创建一个新的RCTView的节点来进行替换当前的View节点视图,并且可以携带一些附加的属性。

           该组件触摸反馈的背景图资源可以通过background属性进行自定义设置

下面一个很简单的使用实例方法如下:

[html] view plain copy
  1. var TouchableDemo =React.createClass({  
  2.   render() {  
  3.     return (  
  4.       <View style={styles.container}>  
  5.         <Text>  
  6.            TouchableNativeFeedback实例  
  7.         </Text>  
  8.         <TouchableNativeFeedback style={{marginTop:20}}>  
  9.             <View style={{width: 150,height: 100, backgroundColor: 'red'}}>  
  10.                <Text style={{margin:30}}>Button</Text>  
  11.             </View>   
  12.         </TouchableNativeFeedback>  
  13.       </View>  
  14.     );  
  15.   }  
  16. });  

运行效果如下:

【React Native开发】React Native控件之Touchable*系列组件详解(18)

          5.2.属性方法介绍

  • TouchableWithoutFeedback 属性,这边TouchableNativeFeedback组件全部可以进行使用
  • background  backgroundPropType  该用来设置背景资源的类型,该属性会传入一个type属性和依赖的额外资源的data的对象。官方推荐采用如下的静态方法来进行生成该dictionary对象

:TouchableNativeFeedback.SelectableBackground()   该会创建使用android默认主题背景(?android:attr/selectableItemBackground)

:TouchableNativeFeedback.SelectableBackgroundBorderless()  该会创建使用android默认的无框的主题背景(?android:attr/selectableItemBackgroundBorderless)。不过该参数需要Android API 21+才可以使用

:TouchableNativeFeedback.Ripple(color,borderless)  该会创建当组件被按下的时候有一个水滴的效果.通过color参数指定颜色,如果borderless为true的时候,那么该水滴效果会渲染到该组件视图的外边。同样该背景类型参数也需要Android API 21+才可以使用

5.3.使用实例代码:

:先设置backgroundPropType为默认的背景效果代码:

[html] view plain copy
  1. var TouchableDemo =React.createClass({  
  2.   render() {  
  3.     return (  
  4.       <View style={styles.container}>  
  5.         <Text>  
  6.            TouchableNativeFeedback实例  
  7.         </Text>  
  8.         <TouchableNativeFeedback style={{marginTop:20}}  
  9.            background={TouchableNativeFeedback.SelectableBackground()}>  
  10.             <View style={{width: 150,height: 100,}}>  
  11.                <Text style={{margin:30}}>Button</Text>  
  12.             </View>   
  13.         </TouchableNativeFeedback>  
  14.       </View>  
  15.     );  
  16.   }  
  17. });  

效果如下:

【React Native开发】React Native控件之Touchable*系列组件详解(18)

()最后总结

          今天我们主要学习一下Touchable*系列组件的使用详解,该系列组件包括四种分别为:TouchableHighlight,TouchableNativeFeedback,TouchableOpacity,TouchableWithoutFeedback。大家有问题可以加一下群React Native技术交流群(282693535)或者底下进行回复一下。

       尊重原创,转载请注明:From Sky丶清(http://blog.csdn.net/developer_jiangqq) 侵权必究!

       关注我的订阅号(codedev123),每天分享移动开发技术(Android/iOS),项目管理以及博客文章!(欢迎关注,第一时间推送精彩文章)