微信小程序‘长按’事件触发‘点击’事件的解决方法
2021/11/1 12:09:33
本文主要是介绍微信小程序‘长按’事件触发‘点击’事件的解决方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
问题:
对于同一控件同时设置@tap和@longpress,会发现长按时先出现@longpress的事件,然后触发点击事件tap。
通过测试,我们发现,小程序中事件执行的顺序是
点击:touchstart → touchend → tap
长按 touchstart → longpress → touchend → tap
解决方法一:
<view v-else class="posterImg" @touchstart="bindTouchStart" @touchend="bindTouchEnd" @longpress="bingLongTap" @tap="bindTap" > <image :src="posterImgUrl" show-menu-by-longpress="true" mode="aspectFit" style="width: 100vw; height: 100vh" /> </view>
touchstart(e) { this.startTime = e.timeStamp; } touchend(e) { this.endTime = e.timeStamp; } tap(e) { if(this.endTime - this.startTime < 350) { console.log("点击") } } longpress(e) { console.log("长按"); }
解决方法二:
data(){ return { lock: false, } } touchend(e) { if(this.lock) { setTimeout(()=>{ this.lock = false; }, 200) } } tap(e) { if(this.lock) return; console.log("点击") } longpress(e) { this.lock = true; console.log("长按"); }
注意:长按触发事件@longTap`和`@longpress`的区别
经过实践,发现在微信和h5端只有longpress起效果,在支付宝小程序端只有longTap起效果,一开始做用了longpress,结果坑了支付宝,这两个还要用区分编译分开来写两套代码
我在想官方不能把不同环境的长按事件合成一个吗?还是有技术难题?
这篇关于微信小程序‘长按’事件触发‘点击’事件的解决方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-13微信小程序如何封装接口域名?-icode9专业技术文章分享
- 2024-11-13如何在微信小程序中实现直传功能?-icode9专业技术文章分享
- 2024-11-13如何在小程序的地图组件中添加标记和文字?-icode9专业技术文章分享
- 2024-11-13在微信小程序的地图组件中如何实现自定义标记和气泡?-icode9专业技术文章分享
- 2024-11-01微信小程序教程:零基础入门到实战
- 2024-11-01微信小程序全栈教程:从入门到实践
- 2024-10-31微信小程序怎么实现关注公众号功能-icode9专业技术文章分享
- 2024-10-30微信小程序cover-view,支持bindtap吗-icode9专业技术文章分享
- 2024-10-30微信小程序的cover-image支持bindtap吗-icode9专业技术文章分享
- 2024-10-30微信小程序web-view怎么设置高度?-icode9专业技术文章分享