zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    java对redis的基本操作(一)
    Android RelativeLayout 属性
    查看jdk的位数
    Java简单文件传输 socket简单文件传输示例
    Java使用socket实现两人聊天对话
    Java观察者设计模式
    Java装饰设计模式的例子
    php邮件发送 phpmailer
    php smarty 缓存和配置文件的基本使用方法
    php smarty insert用法
  • 原文地址:https://www.cnblogs.com/shaoting/p/5931951.html
Copyright © 2011-2022 走看看