• React Native交互组件之Touchable


     React Native交互组件之Touchable:只要在组件外面包一个Touchable组件就可以实现点击交互。

    TouchableHighlight:高亮触摸

    当点击时,组件的透明度会改变,可以看到点击效果,TouchableHighlight只可以进行嵌套一层。其常用属性如下:

      activeOpacity     点击时,组件的透明度。0-1

      onHideUnderlay        当底层被隐藏时调用

      onShowUnderlay    当底层显示时调用

      style   风格

      underlayColor  当点击组件时显示的颜色

    TouchableOpacity:不透明触摸

      activeOpacity   点击时,组件的透明度。0-1

    常用的点击事件如下:

      

    /**
     * Sample React Native App
     * https://github.com/facebook/react-native
     * 周少停 Touchable交互
     * 2016-09-19
     */
    
    import React, { Component } from 'react';
    import {
      AppRegistry,
      StyleSheet,
      Text,
      View,
      TouchableOpacity,
      AlertIOS
    } from 'react-native';
    
    class Project extends Component {
        render() {
        return (
          <View style={styles.container}>
            <TouchableOpacity activeOpacity={0.5} 
    //           onPress = {()=>this.activeEvent('点击')}
    //           onPressIn = {()=>this.activeEvent('按下')}
    //           onPressOut = {()=>this.activeEvent('抬起')}
              onLongPress = {()=>this.activeEvent("长按")}
              >
              <View style={styles.innerViewStyle}>
                <Text>我是可以点击的一个Text文本</Text>
              </View>
            </TouchableOpacity>
          </View>
        );
      }
      activeEvent(event){
        AlertIOS.alert(event);
      }
    }
    
    const styles = StyleSheet.create({
      container: {
        flex: 1,
        justifyContent: 'center',
        alignItems: 'center',
        backgroundColor: '#F5FCFF',
      },
      innerViewStyle: {
        backgroundColor: 'red',
      }
    });
    
    AppRegistry.registerComponent('Project', () => Project);
    

      获取屏幕属性:

    /**
     * Sample React Native App
     * https://github.com/facebook/react-native
     * 周少停 2016-09-12
     */
    
    import React, { Component } from 'react';
    import {
      AppRegistry,
      StyleSheet,
      Text,
      View
    } from 'react-native';
    //引入
    var Dimensions = require('Dimensions')
    class Project extends Component {
      render() {
        return (
          <View style={styles.container}>
            <Text>当前屏幕的宽度:{Dimensions.get('window').width}</Text>
            <Text>当前屏幕的高度:{Dimensions.get('window').height}</Text>
            <Text>当前屏幕的分辨率:{Dimensions.get('window').scale}</Text>
          </View>
        );
      }
    }
    
    const styles = StyleSheet.create({
      container: {
        flex: 1, //充满全屏
        justifyContent: 'center',//主轴对齐方式
        alignItems: 'center',//侧轴对齐方式
        backgroundColor: '#F5FCFF', //背景色
      }
    });
    
    AppRegistry.registerComponent('Project', () => Project);
    

      完整源码下载:https://github.com/pheromone/React-Native-1

  • 相关阅读:
    抽奖概率算法
    redis启动异常
    php如何快速读取大文件
    nginx反向代理解决跨域
    sublime修改侧边栏字体
    curl
    公众号开发一
    数组
    在windows下用vagrant建立lnmp开发环境
    gets--vs--fgets
  • 原文地址:https://www.cnblogs.com/shaoting/p/5931951.html
Copyright © 2020-2023  润新知