当前位置: 首页 > article >正文

基于uniapp vue3 的滑动抢单组件

通过在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>


http://www.kler.cn/a/540781.html

相关文章:

  • 【目标检测xml2txt】label从VOC格式xml文件转YOLO格式txt文件
  • 【Git】ssh如何配置gitlab+github
  • Win11下搭建Kafka环境
  • vscode无法ssh连接远程机器解决方案
  • Render上后端部署Springboot + 前端Vue 问题及解决方案汇总
  • SpringSecurity:授权服务器与客户端应用(入门案例)
  • Markdown+Vscode+Mindmaster打造读书笔记
  • C# Mutex 锁 使用详解
  • 爬虫案例-爬取某度文档利用飞桨ch_pp-ocrv3模型提高对图片的识别
  • [小白入门]PostgreSQL too many clients already
  • 轻松掌握:滤波器截止频率计算
  • 蓝桥杯C语言组:博弈问题
  • PL/SQL语言的云计算
  • C# COM 组件在.NET 平台上的编程介绍
  • qml ToolBar详解
  • 工业相机在工业生产制造过程中的视觉检测技术应用
  • 力扣hot100刷题第一天
  • 高级加密标准AES候选算法之一Crypton
  • ubuntu安装VMware报错/dev/vmmon加载失败
  • Java 8新特性对现有应用程序架构的影响
  • NLP面试之-激活函数
  • 从MyBatis-Plus看Spring Boot自动配置原理
  • 继承(python)
  • 2/10QT
  • centos系统清理docker日志文件
  • 【PG】DROP TABLE ... CASCADE