uni-app双击事件(单击、双击互不干扰)

本文介绍如何在uni-app中实现双击事件,通过记录触摸次数并在短时间内判断是否为双击,有效避免单击与双击事件冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

uni-app中绑定双击事件

功能需求

在uni-app中,很多时候我们需要元素绑定双击事件,比如自定义的视频播放器,双击播放、暂停,但是显示进度条、隐藏进度条。
但是在uni-app官方并没有提供双击事件,那么就需要我们自己来实现双击事件的逻辑。在双击的时候不能触发单击事件,在单击的时候不能触发双击事件。
在做双击事件的时候,大多数情况下就是使用时间戳来实现,两次点击的时间差小于某一个值是判定为双击事件,否则判定为单击事件。

代码实现

下面展示一下我的实现的代码。

//html部分
<view @touchend="maskTouchend"></view>

//js部分
export default {
	data(){
		return {
			touchNum : 0,
		}
	},
	methods:{
		maskTouchend(e){
			this.touchNum ++
			setTimeout(()=>{
				if(this.touchNum == 1){
					console.log('单击')
				}
				if(this.touchNum >= 2){
					console.log('双击')
				}
				this.touchNum = 0
			},250)
		}	
	}
}

其实现原理主要使用的就是setTimeout延时函数的延时执行机制,当用户点击元素的时候,触发延时函数,延时函数在250毫秒之后执行,如果用户在250毫秒之内仅仅只点击了一下,那么在延时函数执行之前,touchNum = 1,所以会满足单击的条件,执行单击逻辑。但是如果用户在250毫秒之内,点击了两次甚至多次,那么此时延时函数还没有执行,而tocuhNum的值已经大于或者等于2了,也就是说在延时函数执行之前,touchNum的值满足双击的条件,不满足单击的条件,所以不会执行单击事件,而执行双击事件。在事件处理完成之后再将touchNum的值还原。

当然还有很多实现的方法,这里就不一一例举了,大家可以多多尝试,只有在不断的尝试和摸索中才能明白他的实现原理,才能真正的学到东西

### uni-appuni-table组件的点击事件使用方法 在 `uni-app` 的开发过程中,`uni-table` 是一个非常实用的表格展示工具。为了增强用户体验,通常需要为表格中的每一行添加点击事件以便执行特定的操作。以下是基于已有引用内容和专业知识总结的两种实现方式。 #### 方法一:通过自定义插槽绑定点击事件 此方法无需修改原生 `tr` 组件结构,而是利用 `uni-table` 提供的自定义单元格功能来绑定点击事件[^3]。 ```html <template> <view> <!-- 表格 --> <uni-table border stripe emptyText="暂无数据"> <uni-tr> <uni-th>列名1</uni-th> <uni-th>列名2</uni-th> </uni-tr> <block v-for="(item, index) in tableData" :key="index"> <uni-tr @click="rowClick(item)"> <uni-td>{{ item.col1 }}</uni-td> <uni-td>{{ item.col2 }}</uni-td> </uni-tr> </block> </uni-table> <!-- 分页 --> <view class="pagination-wrap"> <uni-pagination show-icon :page-size="pageSize" :current="currentPage" :total="total" @change="onPageChange"/> </view> </view> </template> <script> export default { data() { return { pageSize: 10, currentPage: 1, total: 50, tableData: [ { col1: '数据1', col2: '数据A' }, { col1: '数据2', col2: '数据B' } ] }; }, methods: { rowClick(rowItem) { console.log('点击了某一行:', rowItem); // 可在此处触发导航或其他逻辑操作 }, onPageChange(e) { this.currentPage = e.current; console.log('分页切换到第几页:', e.current); // 加载对应的数据 } } }; </script> <style scoped> .pagination-wrap { margin-top: 20px; } </style> ``` 上述代码展示了如何通过 `@click` 监听器为每行绑定点击事件,并传递当前行的数据作为参数。 --- #### 方法二:重写 `tr` 组件并扩展其行为 如果希望更灵活地控制行的行为,则可以考虑重新封装 `tr` 组件,在内部实现更多定制化逻辑。 以下是一个简单的例子: ```javascript // 自定义 tr.js 文件 import Vue from 'vue'; const CustomTr = Vue.extend({ name: 'CustomTr', props: ['rowData'], template: ` <uni-tr @click.native="handleRowClick"> <slot></slot> </uni-tr> `, methods: { handleRowClick() { this.$emit('custom-row-click', this.rowData); // 将数据回传给父级 } } }); export default CustomTr; ``` 接着可以在模板中引入该组件替代默认的 `<uni-tr>` 标签: ```html <template> <view> <uni-table border stripe emptyText="暂无数据"> <custom-tr v-for="(item, index) in tableData" :key="index" :rowData="item" @custom-row-click="rowClicked"> <uni-td>{{ item.col1 }}</uni-td> <uni-td>{{ item.col2 }}</uni-td> </custom-tr> </uni-table> </view> </template> <script> import CustomTr from './path/to/CustomTr'; export default { components: { CustomTr }, data() { return { tableData: [{ col1: '测试1', col2: '值A' }, { col1: '测试2', col2: '值B' }] }; }, methods: { rowClicked(data) { console.log('子组件触发的点击事件:', data); } } }; </script> ``` 这种方法允许开发者完全掌控行级别的交互细节。 --- ### 总结 以上分别介绍了直接绑定点击事件与重构 `tr` 组件这两种不同的解决方案。前者简单易用适合大多数场景;后者则提供了更高的自由度,适用于复杂业务需求下的项目开发。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浮沉逆旅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值