在不同分辨率下,通过vue实现可拖拽弹窗

 原理:在前端页面中,想要实现通过鼠标拖拽改变元素的位置,大体可以有两种方式:

一、通过定位的方式,改变元素的position

二、通过transform的translate属性

推荐使用translate更适合,不会引起页面的重排和重绘,transform类的,可以使用GPU加速,提高浏览器的性能

三、缩放的时候,需要除以不同的缩放系数

const pupopRef = ref<HTMLDivElement>() // 弹窗容器
const titleRef = ref<HTMLDivElement>() // 鼠标按下的位置,我放在标题处
let prevX = 0, prevY = 0  // 记录上一次记录的位置
let countX = 0, countY = 0  // 记录位置累加的结果
let pointDown = false // 判断鼠标是否按下
let scaleRatio = 1 // 缩放系数,因为在不同缩放系数的时候,移动的像素需要乘以缩放系数

const moveFlag = () => countY < 660 && countY > -650 && countX > -3050 && countX < 3050
const moveFun = (e: any) => {
    if (pointDown && pupopRef.value) {
        const { clientX, clientY } = e
        countX += clientX - prevX
        countY += clientY - prevY
        if (moveFlag()) {
            pupopRef.value.style.transform = `translate(${countX / scaleRatio}px, ${countY / scaleRatio}px)`
        }
        prevX = clientX
        prevY = clientY
    }
}
const pointUpFun = () => pointDown = false
const resizeFun = () => scaleRatio = window.innerWidth / 6720

onMounted(() => {
    if (titleRef.value) {
        titleRef.value.addEventListener('pointerdown', ({ clientX, clientY }) => {
            prevX = clientX
            prevY = clientY
            pointDown = true
        })
        window.addEventListener('pointermove', moveFun)
        window.addEventListener('pointerup', pointUpFun)
    }

    window.addEventListener('resize', resizeFun)
    scaleRatio = window.innerWidth / 6720
})

onBeforeUnmount(() => {
    // 关闭弹窗的时候移除监听
    window.removeEventListener('pointermove', moveFun)
    window.removeEventListener('pointerup', pointUpFun)
    window.removeEventListener('resize', resizeFun)
})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值