【uniapp中swiper禁止左右滑动、允许上下滑动】

问题描述

在某些极端的应用场景下,可能会碰到禁止swiper左右滑动,但是允许上下滑动。


解决方案:

思路:判断用户手势,将操作回溯

<swiper :disable-touch="false" duration="100" class="swiper" :current="scroll" @change="swiperChange" :style="{ height: swiperHeight + 'px' }">
	<swiper-item :key="item" @touchstart="itemTouchStart" @touchend="itemTouchEnd" v-for="item in 6">
		{{item}}
	</swiper-item>
</swiper>
const scroll = ref(0)			//当前进度
const itemTouchStartX = ref()	//按下的位置
const postion = ref('')			//左滑还是右滑

/** 触摸屏幕  */
const itemTouchStart = (e : any) => {
	//记录起始位置
	itemTouchStartX.value = e.changedTouches[0].pageX
}

/** 触摸结束  */
const itemTouchEnd = (e : any) => {
	/** 左滑还是右滑  */
	if (itemTouchStartX.value - e.changedTouches[0].pageX > 30) postion.value = 'right'
	if (e.changedTouches[0].pageX - itemTouchStartX.value > 30) postion.value = 'left'
}

/** 滑动控制器 */
const swiperController = () => {
	if (postion.value) {
		/** 因为异步原因,必须包一个定时器加入宏任务*/
		setTimeout(() => {
			/** 用户向左滑动,进度会-1, 咱们把进度++,就又回到了当前的item。右边同理 */
			postion.value === 'left' ? scroll.value++ : scroll.value--
			/** 一定要清空 postion , 不然死循环了*/
			postion.value = ''
		}, 50)
	}
}

/** 左右滑动成功的回调  */
const swiperChange = (e : any) => {
	swiperController()
}

  • 12
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值