监听标签的触摸/鼠标滑动事件,添加元素的切换动画,效果如下:

事件监听

鼠标事件和触摸事件监听:

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事件:当系统停止跟踪触摸的时候触发。关于这个事件的确切出发时间,文档中并没有具体说明。。。不建议使用

事件处理

添加全局字段:

    locationStartX: number = 0;
    locationEndX: number = 0;
滑动处理,超出滑动阈值后,更新相关状态
 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 页面/内容 触摸/点击滑动的更多相关文章

  1. Swipe JS – 移动WEB页面内容触摸滑动类库

    想必做移动前端的同学经常会接到这样子的一个需求,就是在移动设备页面上的banner图能够用手指触摸左右或上下的滑动切换,这在移动设备是个很常见的一个效果,其用户体验远甚于点击一个按钮区域,通过手指的触 ...

  2. 基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操作

    在前面介绍了很多篇相关的<Bootstrap开发框架>的系列文章,这些内容基本上覆盖到了我这个Bootstrap框架的各个主要方面的内容,总体来说基本达到了一个稳定的状态,随着时间的推移可 ...

  3. web页面内容优化管理与性能技巧

    来源:GBin1.com 回 想一下,以前我们不得不花费大量时间去优化页面内容(图片.CSS等等),如今用户有更快速的互联网链接,我们似乎能够使用更大的图像或更大的闪 存文件,里面包含的有视频或者图片 ...

  4. (转)基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操作

    http://www.cnblogs.com/wuhuacong/p/5147368.html 在前面介绍了很多篇相关的<Bootstrap开发框架>的系列文章,这些内容基本上覆盖到了我这 ...

  5. web 页面内容优化管理与性能技巧

    回想一下,以前我们不得不花费大量时间去优化页面内容(图片.CSS等等),如今用户有更快速的互联网链接,我们似乎能够使用更大的图像或更大的闪存文件,里面包含的有视频或者图片.然而,随着移动开发的兴起,我 ...

  6. js打印WEB页面内容代码大全

    第一种方法:指定不打印区域 使用CSS,定义一个.noprint的class,将不打印的内容放入这个class内. 详细如下: <style media=print type="tex ...

  7. 用A标签实现页面内容定位 点击链接跳到具体位置

    经常在维基百科等网站看到目录列表,点击链接会跳到具体的位置,小美眉一直在问是怎么做到的,其实挺简单的,用A标签实现页面内容定位就行了.实例参考微信营销理论手册的目录. 首先用A标签定义目录的链接. & ...

  8. 知名网站内部资料:WEB页面内容优化管理与性能技巧

    回想一下,以前我们不得不花费大量时间去优化页面内容(图片.CSS等等),如今用户有更快速的互联网链接,我们似乎能够使用更大的图像或更大的闪 存文件,里面包含的有视频或者图片.然而,随着移动开发的兴起, ...

  9. web页面内容打印总结

    web页面打印有两种,一种是直接调用window.print()命令操作,一种是使用ActiveX插件(Object标签)操作,但是第二种只支持IE内核的浏览器. 示例1: <!DOCTYPE ...

  10. Winfrom 抓取web页面内容代码

    WebRequest request = WebRequest.Create("http://1.bjapp.sinaapp.com/play.php?a=" + PageUrl) ...

随机推荐

  1. 【NAS使用心得】使用Synology Photos管理照片

    整理方式 1.本地没有整理或只按年份整理的:时间线模式下直接上传,让软件自己按照片创建时间生成文件夹:有按年份生成相册需求的,可以用"选择照片以创建相册"功能,找到年份文件夹,全选 ...

  2. How to enable CIFS in kernel 4.9

    kernel config 要打开这几项

  3. C# winform DataGridView 一列显示星号

    private void myDataGrid_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventA ...

  4. Leecode 160.相交链表(Java 哈希表、双指针 两种方法)

    找两个链表第一次指针相同的地方     想法:(本来是没有的,因为没读懂题目描述= =) 1.两个指针,长的先走(长减短相差的长度)这么多的步数,然后就可以开始比较指针,直到指向为空,期间如果指针相同 ...

  5. js指南

    1.for /in: 与for/of相比,可迭代对象不同,in后面可以是任意对象.数组.字符串.集合和映射可迭代. object.keys()   object.values()   object.e ...

  6. AssetBuddle(一)

    一·含义 一个压缩文件,针对于特定平台的资产压缩包.资产包括模型,贴图,预制体,音效,材质球等,注意不包括c#脚本. 二·作用 相对于resource文件夹下面的东西打包后定死只读,无法修改. AB包 ...

  7. 第七章ssh sftp scp

    第七章ssh sftp scp 对数据进行了加密和压缩 版本号协商,可能客户端和服务端的版本号不一致,服务端向客户端发送一个ssh协商,告诉客户端使用的ssh协议的版本号是多少,客户端在接收到了这个协 ...

  8. java生态下的后端开发都有哪些技术栈?

    前言 我08年毕业,那时(2003-2010)C#还比较时髦的,大学跟着老师进修的,毕业后就从事winform窗体应用程序开发.慢慢的web网站兴起,就转到aps.net开发,再到后来就上了另一艘船( ...

  9. vulnhub靶场之PYLINGTON: 1

    准备: 攻击机:虚拟机kali.本机win10. 靶机:Pylington: 1,下载地址:https://download.vulnhub.com/pylington/pylington.ova,下 ...

  10. progress监视linux命令进程

    progress监视linux命令进程 可以查看哪些命令进程 cp mv tar dd gzip cat grep 如何在ubuntu安装 sudo apt install progress 使用方法 ...