混合开发的大趋势之一React Native手势行为那些事
转载请注明出处:王亟亟的大牛之路
最近项目部分模块重构,事情有点多,学习进度有所延缓,外加一直在吸毒(wow你懂的),导致好多天没发问了,其实这部分知识月头就想写了,一直没补。
话不多说先安利:https://github.com/ddwhan0123/Useful-Open-Source-Android (下拉刷新模块单独区分开了)
rn也有类似于安卓的onClick行为
点击事件 onPress
长按事件 onLongPress
以及 “按下“ onPressIn “松开“ onPressOut
触控相关的组件分别为
TouchableHighlight
TouchableNativeFeedback
TouchableOpacity
TouchableWithoutFeedback
让我们用一个例子 来试验下这些内容
源码地址:https://github.com/ddwhan0123/ReactNativeDemo
import React, {Component, Navigator} from 'react';
import {
AppRegistry,
View,
StyleSheet,
Text,
BackAndroid,
Platform,
ToastAndroid,
TouchableHighlight,
TouchableNativeFeedback,
TouchableWithoutFeedback,
} from 'react-native';
var titleStr;
var _navigator;
var name;
//返回键监听行为
BackAndroid.addEventListener('hardwareBackPress', function() {
if (_navigator == null) {
return false;
}
if (_navigator.getCurrentRoutes().length === 1) {
return false;
}
_navigator.pop();
return true;
});
export default class Main extends Component {
constructor(props) {
super(props);
_navigator = this.props.navigator;
titleStr = this.props.titleStr;
name = this.props.name;
}
//常规点击事件调用
//常规的概念:手指在控件区域内按下,手指在控件区域内离开
_textOnPress(){
ToastAndroid.show(' 这是一个可点击的Text', ToastAndroid.SHORT)
}
//手指在控件区域内按下,无论离不离开都立即调用
_textOnPressIn(){
ToastAndroid.show(' PressIn被触发', ToastAndroid.SHORT)
}
//手指在控件区域按下,无论在不在控件区域内离开都会被调用
_textOnPressOut(){
ToastAndroid.show(' OnPressOut被触发', ToastAndroid.SHORT)
}
//手指在控件区域内按下持续一定时间,手指在控件区域内离开(时间可自定义)
_textOnLonePress(){
ToastAndroid.show('这是一个长按波纹Text', ToastAndroid.SHORT)
}
//按下去没有ui反馈,但是回调已经触发
_textNoFeedbackOnPress(){
ToastAndroid.show('这是一个按下去没有实际效果的Text', ToastAndroid.SHORT)
}
render() {
return (
<View style={{flex : 1,flexDirection : 'column'}}>
<Text>{titleStr}
页面 获得的参数: value = {name}
</Text>
<TouchableHighlight
onPress={this._textOnPress}
onPressIn={this._textOnPressIn}>
<Text style={{marginTop:20}}>
这是一个可点击的Text还响应了OnPressIn
</Text>
</TouchableHighlight>
{/* android md风格的动画效果,需要在外层套一个view不然,波纹扩散到哪去? */}
<TouchableNativeFeedback
onLongPress={this._textOnLonePress}
onPressOut={this._textOnPressOut}>
<View style={{width: 150, height: 28, backgroundColor: 'red',marginTop:20}}>
<Text>
这是一个长按波纹Text
</Text>
</View>
</TouchableNativeFeedback>
<TouchableWithoutFeedback
onPress={this._textNoFeedbackOnPress}>
<View style={{marginTop:20}}>
<Text >
这是一个没有点击效果的Text
</Text>
</View>
</TouchableWithoutFeedback>
</View>
);
}
}
AppRegistry.registerComponent('Main', () => Main);
TouchableWithoutFeedback这个组件只响应touch手势,不增加点击态
TouchableNativeFeedback这个组件只能用在安卓上,类似于Material Design的点击波纹效果
TouchableOpacity这个组件用来给为内部元素在点击时添加透明度
TouchableHighlight会给内部元素增加绑定事件之,还会在ui上显示点击区域的响应
什么?你要自定义?
下次再讲 进阶篇 关于 Gesture Responder System
混合开发的大趋势之一React Native手势行为那些事的更多相关文章
- 混合开发的大趋势之一React Native与Android联调
转载请注明出处:王亟亟的大牛之路 先安利,有空我都会更,看到的好东西都会放进来:https://github.com/ddwhan0123/Useful-Open-Source-Android 公司某 ...
- 混合开发的大趋势之一React Native之页面跳转
转载请注明出处:王亟亟的大牛之路 最近事情有点多,没有长时间地连贯学习,文章也停了一个多礼拜,愧疚,有时间还是继续学习,继续写! 还是先安利:https://github.com/ddwhan0123 ...
- 混合开发的大趋势之一React Native之简单的登录界面
转载请注明出处:王亟亟的大牛之路 这些天都在学习RN这部分吧,然后写了个简单的登陆业务,从"实战"中讲解吧 还是继续安利:https://github.com/ddwhan0123 ...
- 混合开发的大趋势之一React Native之页面跳转(2)+物理返回+特定平台代码
转载请注明出处:这里写链接内容 今天是10月份的最后一天,我加了3个月来的第一个班,挤出了这篇. 废话不多先安利,然后继续学习 RN 有好东西都往里面丢,努力做好归纳 https://github.c ...
- 混合开发的大趋势之一React Native之Image (脑动理解)
文章是宝宝自己写的,你可以转走,标明哪来的就行王亟亟的大牛之路 国庆这些天要么旅游要么WOW,感觉整个人都废了.. 直接从黄种人晒成了非洲大酋长..然而还是无橙,这礼拜要做7天,昨天把单元测试的东西整 ...
- 混合开发的大趋势之 一个Android程序员眼中的 React.js 块级作用域 和 let
转载请注明出处:王亟亟的大牛之路 最近都有事干然后,快到月底了这个月给CSDN的博文也就两篇,想想也蛮多天没更了,那就来一篇. 老规矩,先安利:https://github.com/ddwhan012 ...
- 混合开发的大趋势之 一个Android程序员眼中的 React.js 箭头函数,const, PropTypes
转载请注明出处:王亟亟的大牛之路 昨天写了篇React.js的开头之作,讲了讲块级作用域和let,先安利:https://github.com/ddwhan0123/Useful-Open-Sourc ...
- 移动开发发展方向-----Hybird混合开发3大方案
移动开发发展方向-----Hybird混合开发3大方案
- 浅谈移动应用的跨平台开发工具(Xamarin和React Native)
谈移动应用的跨平台开发不能不提HTML5,PhoneGap和Sencha等平台一直致力于使用HTML5技术来开发跨平台的移动应用,现在看来这个方向基本算是失败的,基于HTML5的移动应用在用户体验上与 ...
随机推荐
- CodeForces 24A Ring road(dfs)
A. Ring road time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...
- Code Forces 20A BerOS file system
A. BerOS file system time limit per test 2 seconds memory limit per test 64 megabytes input standard ...
- [报错] Xcode Error-Could not insert new outlet connection: Could not find any information for the class named "xxx"
当从StoryBoard或xib中需要将控件绑定类文件时(OC中是.m文件,Swift中是.swift文件) 当按住control键将控件往类文件中拖拽后,填写控件的name后,点击connect时 ...
- Storm-源码分析- Messaging (backtype.storm.messaging)
先定义两个接口和一个类 TaskMessage类本身比较好理解, 抽象storm的message格式 对于IContext, 注释也说了, 定义messaging plugin, 通过什么渠道去发送m ...
- python - while语句/pass/死循环/break/continue/while...else...
程序开发的原则: 写重复代码 是可耻的行为: 1.while 条件: 执行代码... #循环打印0-100count = 0 while count <= 100: print("lo ...
- java.math.BigDecimal
package day14; import java.math.BigDecimal; /** * Created by admin on 2018/11/24. * 看程序写结果:结果和我们想的有一 ...
- vs2010 重新配置帮助文档
1.VS2010帮助文件不支持重新配置,这个时候打开C:\Program Files\Microsoft Help Viewer\1.0目录,找到“HelpLibManager.exe.config” ...
- 007-Shell test 命令,[],[[]]
一.概述 test 命令用于检查某个条件是否成立,它可以进行数值.字符和文件三个方面的测试. 其中[]完全等价于test,只是写法不同.双中括号[[]]基本等价于[],它支持更多的条件表达式,还允许在 ...
- 使用Robomongo连接数据库不成功:没有启动MongoDB
启动MongoDB ➜ ~ mongod --07T16:: I CONTROL [initandlisten] MongoDB starting : pid= port= dbpath=/data/ ...
- TensorFlow学习笔记(三)-- feed_dict 使用
个人理解:就是TF的一种输入语法. 跟C语言的scanf(),C++的 cin>> 意思差不多,只是长相奇怪了点而已. 做完下面几个例子,基本也就适应了. 首先占位符申请空间:使用的时候, ...