移动端基本touch事件实现

 

原文链接:mx前端-前端园地 

http://www.idouxs.cn/?p=917

touch事件模型现阶段规定了很多种类型的触摸事件,以下三种是应用最广泛的:

 

1. Touchstart:手指刚放到屏幕上某个DOM元素里的时候该元素触发

2. Touchmove:手指紧贴屏幕的时候连续触发

3. Touchend:手指从屏幕上抬起的时候触发

 

这些个事件都会顺着DOM树向上冒泡,并产生一个触摸事件对象。

Touches:表示当前位于屏幕上的所有手指动作的列表,是一个TouchList类型的对象,TouchList是一个类数组对象,它里面装的是Touch对象。

     pageX / pageY:触摸点相对于页面的位置

 

来看一个简单例子:

//touch所有类型事件都会冒泡

document.addEventListener('touchstart', function (e){

//如果阻止了 touchstart 的默认行为,后续的mousedown 和 click 事件将不会触发
e.preventDefault()

//如果已经生成小光点了就直接返回
if (spot){
return;
}
spot = document.createElement('div');
spot.classList.add('spot');

//这里设置的光点大小是70px,减去35px是为了让光点处于手指中间
spot.style.top = e.touches[0].pageY - 35 + 'px';
spot.style.left = e.touches[0].pageX - 35 + 'px';
document.body.appendChild(spot);
},false)

 

document.addEventListener('touchmove',function (e){

//阻止 touchmove 的默认行为,后续的 mousemove 事件将不会触发
e.preventDefault()
if (spot){
spot.style.top = e.touches[0].pageY - 35 + 'px';
spot.style.left = e.touches[0].pageX - 35 + 'px';
}
})

 

document.addEventListener('touchend',function (e){

//阻止 touchend 默认行为,后续的 mouseup 和 click 事件将不会触发
e.preventDefault();
if(spot){

//删除这个光点
document.body.removeChild(spot);
spot = null;
}
})

以上代码效果:当你将手指放到屏幕上时,屏幕上就会出现一个“光点”,随着手指移动,“光点”也会随之移动,如果手指移开屏幕,“光点”也会随之消失。

 

可以看到以上代码里无时无刻都在阻止默认的鼠标事件,在正常情况下,一次触摸会按下面这样的顺序触发事件:

touchstart   ~>

mousedown  ~>

touchmove  ~>

mousemove  ~>

touchend  ~>

mouseup  ~>

 

demo演示:请手机访问:

http://www.idounao.com/demo/basictouch.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现移动touch事件的横向滑动列表效果可以使用原生的JavaScript和CSS3来实现。 首先,我们需要在HTML中创建一个容器元素,用来包含列表项。容器元素需要设置overflow-x属性为scroll,使得内容超出容器范围时可以滚动。 ```html <div class="container"> <ul class="list"> <li>项1</li> <li>项2</li> <li>项3</li> <li>项4</li> <li>项5</li> </ul> </div> ``` 然后,在CSS中,我们需要设置容器元素和列表项的样式,以及使用CSS3的transition属性来实现平滑的过渡效果。 ```css .container { width: 100%; overflow-x: scroll; -webkit-overflow-scrolling: touch; /* 添加iOS滚动效果 */ } .list { display: flex; flex-wrap: nowrap; /* 设置列表项不换行 */ transition: transform 0.3s ease; /* 添加平滑的过渡效果 */ } .list li { width: 100px; height: 100px; margin-right: 10px; background-color: #ccc; } ``` 最后,在JavaScript中,我们需要监听容器元素的touchstart、touchmove和touchend事件,计算滑动距离并通过改变列表项的transform属性来实现横向滑动效果。 ```javascript const container = document.querySelector('.container'); const list = document.querySelector('.list'); let isDragging = false; let startPosition = 0; let currentTranslate = 0; let prevTranslate = 0; let animationId = 0; container.addEventListener('touchstart', touchStart); container.addEventListener('touchmove', touchMove); container.addEventListener('touchend', touchEnd); container.addEventListener('touchcancel', touchEnd); function touchStart(event) { if (event.target.classList.contains('list')) { isDragging = true; startPosition = event.touches[0].clientX; animationId = requestAnimationFrame(updateAnimation); container.classList.add('grabbing'); } } function touchMove(event) { if (isDragging) { const currentPosition = event.touches[0].clientX; currentTranslate = prevTranslate + currentPosition - startPosition; } } function touchEnd() { isDragging = false; cancelAnimationFrame(animationId); prevTranslate = currentTranslate; container.classList.remove('grabbing'); } function updateAnimation() { list.style.transform = `translateX(${currentTranslate}px)`; animationId = requestAnimationFrame(updateAnimation); } ``` 通过以上代码,我们就成功地实现移动touch事件的横向滑动列表效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值