web 页面/内容 触摸/点击滑动
监听标签的触摸/鼠标滑动事件,添加元素的切换动画,效果如下:

事件监听
鼠标事件和触摸事件监听:
1 componentDidMount() {
2 var teachingReportDiv = document.getElementById("teachingReport") as HTMLElement;
3 teachingReportDiv.onmousedown = this.onMouseDown;
4 teachingReportDiv.onmouseup = this.onMouseUp;
5 teachingReportDiv.addEventListener('touchstart', this.onTouchStart, false);
6 teachingReportDiv.addEventListener('touchmove', this.onTouchMove, false);
7 teachingReportDiv.addEventListener('touchend', this.onTouchEnd, false);
8 }
触摸事件,不能HTMLElement.ontouchstart添加事件监听,可以EventListener或者在标签中添加
1 <div id="teachingReport" onTouchStart={(event) => this.onTouchStart(event)}/>
触摸事件有以下几个:
touchstart事件:手指触摸时候触发(支持多指触发)touchmove事件:手指在滑动的时候连续地触发。在这个事件发生期间,调用preventDefault()事件可以阻止滚动,当然也不能滥用否则会影响原有页面的上下滚动等。touchend事件:手指从屏幕上离开的时候触发touchcancel事件:当系统停止跟踪触摸的时候触发。关于这个事件的确切出发时间,文档中并没有具体说明。。。不建议使用
事件处理
添加全局字段:
1 onTouchStart = (event) => {
2 this.locationStartX = event.targetTouches[0].pageX;
3 }
4 onTouchMove = (event) => {
5 // event.preventDefault();
6 this.locationEndX = event.targetTouches[0].pageX;
7 }
8 onTouchEnd = (event) => {
9 const locationChangedX = this.locationEndX < this.locationStartX;
10 if (Math.abs(locationChangedX) > 10) {
11 const isSlidingToRight=locationChangedX<0;
12 }
13 }
添加切换动画
动画,可以通过state参数触发
1 <div className="reportContent-img" style={{ animation: this.state.selectTabIndex == 0 ? 'showFromLeft 0.4s forwards' : 'hideToLeft 0.2s forwards' }}></div>
动画数据参考:
1 //动画
2 @keyframes showFromLeft {
3 from {
4 opacity: 0;
5 transform: translateX(-100px);
6 }
7 to {
8 opacity: 1;
9 transform: translateX(0px);
10 }
11 }
12 @keyframes showFromRight {
13 from {
14 opacity: 0;
15 transform: translateX(100px);
16 }
17 to {
18 opacity: 1;
19 transform: translateX(0px);
20 }
21 }
22 @keyframes hideToLeft {
23 from {
24 opacity: 1;
25 transform: translateX(0px);
26 }
27 to {
28 opacity: 0;
29 transform: translateX(-100px);
30 }
31 }
32 @keyframes hideToRight {
33 from {
34 opacity: 1;
35 transform: translateX(0px);
36 }
37 to {
38 opacity: 0;
39 transform: translateX(100px);
40 }
41 }
web 页面/内容 触摸/点击滑动的更多相关文章
- Swipe JS – 移动WEB页面内容触摸滑动类库
想必做移动前端的同学经常会接到这样子的一个需求,就是在移动设备页面上的banner图能够用手指触摸左右或上下的滑动切换,这在移动设备是个很常见的一个效果,其用户体验远甚于点击一个按钮区域,通过手指的触 ...
- 基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操作
在前面介绍了很多篇相关的<Bootstrap开发框架>的系列文章,这些内容基本上覆盖到了我这个Bootstrap框架的各个主要方面的内容,总体来说基本达到了一个稳定的状态,随着时间的推移可 ...
- web页面内容优化管理与性能技巧
来源:GBin1.com 回 想一下,以前我们不得不花费大量时间去优化页面内容(图片.CSS等等),如今用户有更快速的互联网链接,我们似乎能够使用更大的图像或更大的闪 存文件,里面包含的有视频或者图片 ...
- (转)基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操作
http://www.cnblogs.com/wuhuacong/p/5147368.html 在前面介绍了很多篇相关的<Bootstrap开发框架>的系列文章,这些内容基本上覆盖到了我这 ...
- web 页面内容优化管理与性能技巧
回想一下,以前我们不得不花费大量时间去优化页面内容(图片.CSS等等),如今用户有更快速的互联网链接,我们似乎能够使用更大的图像或更大的闪存文件,里面包含的有视频或者图片.然而,随着移动开发的兴起,我 ...
- js打印WEB页面内容代码大全
第一种方法:指定不打印区域 使用CSS,定义一个.noprint的class,将不打印的内容放入这个class内. 详细如下: <style media=print type="tex ...
- 用A标签实现页面内容定位 点击链接跳到具体位置
经常在维基百科等网站看到目录列表,点击链接会跳到具体的位置,小美眉一直在问是怎么做到的,其实挺简单的,用A标签实现页面内容定位就行了.实例参考微信营销理论手册的目录. 首先用A标签定义目录的链接. & ...
- 知名网站内部资料:WEB页面内容优化管理与性能技巧
回想一下,以前我们不得不花费大量时间去优化页面内容(图片.CSS等等),如今用户有更快速的互联网链接,我们似乎能够使用更大的图像或更大的闪 存文件,里面包含的有视频或者图片.然而,随着移动开发的兴起, ...
- web页面内容打印总结
web页面打印有两种,一种是直接调用window.print()命令操作,一种是使用ActiveX插件(Object标签)操作,但是第二种只支持IE内核的浏览器. 示例1: <!DOCTYPE ...
- Winfrom 抓取web页面内容代码
WebRequest request = WebRequest.Create("http://1.bjapp.sinaapp.com/play.php?a=" + PageUrl) ...
随机推荐
- SDC细节归纳
能否写出一份严谨的SDC约束文件,决定了芯片tapeout后数字电路能否正常工作,或者少一些bug.所以写好SDC约束文件,是芯片设计的关键一步. 因此,归纳.整理SDC约束的细节要点很重要,有助于减 ...
- 4.javaweb-thymeleaf
1.知识回顾: 1. post提交方式下的设置编码,防止中文乱码 request.setCharacterEncoding("utf-8"); get提交方式,tomcat8开始, ...
- 关于PB用JDBC连接MySQL,亲测有效
以前自学过一段时间的PB,数据窗口让人印象深刻,前段时间,在西瓜视频看到有人录制了PB的教学视频,让我想起以前自学的那段时光,遇到了问题,也不知道问谁,现在网络发达,可以在网上查找问题,但是有大多数博 ...
- jvm垃圾收集器汇总
1.吞吐量和延时 吞吐量:吞吐量指的是cpu的利用时间,计算公式是 运行用户代码时间 / (用户代码时间 + 垃圾收集时间),吞吐量越大说明cpu的利用率越大. 延时:延时指的是停顿时间,用户代码不 ...
- useBean类属性[javaChuLi.LoginBean]的值无效
今天遇到了一个错误,如图 参见:JSP 中给定的 useBean 标签的 class 属性的值无效_dkawskawx的博客-CSDN博客
- syn flood
from scapy.all import * import random # 生成随机的IP def randomIP(): ip = ".".join(map(str, (ra ...
- gitlab-ce安装
# vim /etc/yum.repos.d/gitlab-ce.repo [gitlab-ce] name=Gitlab CE Repository baseurl=https://mirrors. ...
- 网络安全(中职组)-B模块:Web安全渗透测试
Web安全渗透测试任务环境说明: 服务器场景:PYsystem003(关闭链接)服务器操作系统:未知用户名:未知 密码:未知 1. 通过浏览器访问http://靶机服务器IP/1,对该页面进行渗 ...
- Python学习笔记--PySpark的基础学习(二)
filter方法(过滤想要的数据进行保留) 具体实现(保留奇数): 具体实现(保留偶数): distinct方法(对RDD进行去重,返回新的RDD) 且无需传参 具体实现(去重): sortBy方法( ...
- BOW/DOM(上)
BOM 原生对象:成为js中的内置对象,就是由 js 中的构造函数创建的对象就被称为原生对象:Object.Number.Array.Date.String.... 宿主对象:web运行环境,也就是w ...