vue项目实现堆叠卡片拖动切换效果

实际效果

实现流程

1. 实现卡片位置堆叠

将父元素的 position 设置成relative ,卡片的position 设置成 absolute 即可。

2. 消除图片的移动

如果卡片上有图片,默认拖动的时候就会导致像上图一样变成了选中图片移动,从而没法触发拖动事件。消除图片移动的方式就是在标签上添加ondragstart="return false;" 事件

html 复制代码
<el-image ondragstart="return false;" :src="" fit="fill" alt=""/>

3. 实现拖动事件

在卡片组件上添加@mousedown, 和 @mouseup 事件。监听鼠标的按下和抬上。当按下时记录鼠标的位置。然后给document 注册 mousemove 事件监听鼠标滑动时的位置,这个位置差代表卡片要滑动的距离,通过改变卡片的transform 样式实现卡片的切换。鼠标抬起时取消滑动事件以及处理卡片(删除或者复位)。

html 复制代码
<UserDetail class="card" :data="item" v-for="(item, index) in matchUsers" 
            @mousedown.stop="handleMouseDown($event)"
            @mouseup.stop = "handleMouseUp($event, index)"
            />
js 复制代码
// 记录按下的位置
    const position_X = ref(0)
    // 记录移动的当前位置
    const cur_X = ref(0)
    // 记录卡片元素
    const card = ref({})
    // 鼠标按下事件
    function handleMouseDown(event){
        // 获得最上方的卡片元素
        card.value = document.getElementsByClassName('card')[pageData.matchUsers.length - 1]
     	// 给两个位置赋初值
        position_X.value = event.clientX
        cur_x.value = event.clientX
        // 注册移动事件
        document.addEventListener('mousemove', handleMouseOver)
    }
    // 鼠标移动时设置卡片旋转移动
    function handleMouseOver(e){
        cur_X.value =  e.clientX
            // card.value.style.left = (cur_x - position_X.value) + 'px'
            card.value.style.transform = `translate(${cur_X.value - position_X.value}px, 0px) rotate(${(cur_X.value - position_X.value) / 20}deg)`;
    }
    // 鼠标抬起,移除移动事件,如果偏移量超过200则将卡片删除,否则复位。
    function handleMouseUp(event, index){
        document.removeEventListener('mousemove', handleMouseOver)
        if(cur_X.value - position_X.value > 200 || cur_X.value - position_X.value < -200){
            pageData.matchUsers.splice(index, 1)
        }else{
            card.value.style.transform = `translate(0px, 0px) rotate(0deg)`;
        }
    }
相关推荐
Mr Xu_7 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝7 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions7 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发7 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_7 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞057 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、7 小时前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao7 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly7 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
一 乐8 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端