当前位置: 代码网 > it编程>编程语言>Javascript > 基于uniapp vue3 的滑动抢单组件实例代码

基于uniapp vue3 的滑动抢单组件实例代码

2025年02月13日 Javascript 我要评论
通过在onmounted获取movable-area与movable-view实例,计算出可滑动的距离效果图:代码:<template> <view class="slider-c

通过在onmounted获取movable-area与movable-view实例,计算出可滑动的距离

效果图:

代码:

<template>
  <view class="slider-container">
    <movable-area class="movable-area" id="movablearea">
      <movable-view 
        class="slider-button"
        direction="horizontal"
        :x="sliderx"
        @change="onsliderchange"
        @touchend="onsliderend"
        id="movableview"
      >
        <text class="arrow-icon">»</text>
        <text>slide to grab order</text>
      </movable-view>
    </movable-area>
  </view>
</template>
<script setup>
import { ref, onmounted } from "vue";
const sliderx = ref(0); // 滑块 x 轴位置
const maxx = ref(0);    // 最大可滑动距离
onmounted(() => {
  getmaxx(); // 组件加载后计算最大可滑动距离
});
const getmaxx = () => {
  uni.createselectorquery()
    .select("#movablearea")
    .boundingclientrect(arearect => {
      uni.createselectorquery()
        .select("#movableview")
        .boundingclientrect(viewrect => {
          if (arearect && viewrect) {
            maxx.value = arearect.width - viewrect.width;
            console.log("动态计算 maxx:", maxx.value);
          }
        })
        .exec();
    })
    .exec();
};
const onsliderchange = (event) => {
  const x = event.detail.x;
  console.log("当前滑动位置:", x);
  if (x >= maxx.value) {
    console.log("滑到了最右边");
    onsliderend();
  }
};
const onsliderend = () => {
  console.log("滑动结束,执行逻辑...");
  sliderx.value = 0; // 可选择让滑块复位
};
</script>
<style>
.slider-container {
			position: relative;
			width: 100%;
			height: 88rpx;
			margin-top: 30rpx;
			background-color: #f0f0f0;
			border-radius: 8rpx;
			overflow: hidden;
			movable-area {
				width: 100%;
				height: 100%;
				background: linear-gradient(90deg, #4080ff 0%, #4080ff 100%);
			}
			.slider-button {
				width: 300rpx;
				height: 88rpx;
				background-color: #4080ff;
				border-radius: 8rpx;
				display: flex;
				align-items: center;
				justify-content: center;
				color: #ffffff;
				font-size: 28rpx;
				z-index: 1;
				.arrow-icon {
					margin-right: 10rpx;
					font-size: 32rpx;
				}
			}
		}
</style>

到此这篇关于基于uniapp vue3 的滑动抢单组件的文章就介绍到这了,更多相关uniapp vue3滑动抢单内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com