gpt4 book ai didi

javascript - 如何限制可拖动区域?它在顶部和左侧起作用,但在右侧和底部不起作用

转载 作者:行者123 更新时间:2023-11-30 19:09:26 24 4
gpt4 key购买 nike

所以我试图阻止 draggable 内容overflow 主体。

它在顶部和左侧有效

无法限制右侧和底部。

            e.pageX -= e.offsetX;
e.pageY -= e.offsetY;

// left/right constraint
if (e.pageX - dragoffset.x < 0) {
offsetX = 0;
} else if (e.pageX + dragoffset.x > document.body.clientWidth) {
offsetX = document.body.clientWidth - e.target.clientWidth;
} else {
offsetX = e.pageX - dragoffset.x;
}

// top/bottom constraint

if (e.pageY - dragoffset.y < 0) {
offsetY = 0;
} else if (e.pageY + dragoffset.y > document.body.clientHeight) {
offsetY = document.body.clientHeight - e.target.clientHeight;
} else {
offsetY = e.pageY - dragoffset.y;
}

el.style.top = offsetY + "px";
el.style.left = offsetX + "px";
}
});
};

此外,当我拖动它们时,我的 div 变得故障。当选中其中的文本时,它们只会停在右侧和底部。

最佳答案

拖放库具有限制可拖动对象移动的功能

https://github.com/dragee/dragee

默认情况下,它限制元素在 container 内的移动。它考虑了元素的大小。

import { Draggable } from 'dragee'
new Draggable(element, { container: document.body })

同时可以使用自定义绑定(bind)函数

import { Draggable, BoundToRectangle, Rectangle } from 'dragee'
new Draggable(element, {
bound: BoundToRectangle.bounding(Rectangle.fromElement(document.body, document.body))
})

BoundToElement 描述了你需要的限制条件

class BoundToRectangle {
constructor(rectangle) {
this.rectangle = rectangle
}

bound(point, size) {
const calcPoint = point.clone()
const rectP2 = this.rectangle.getP3()

if (this.rectangle.position.x > calcPoint.x) {
(calcPoint.x = this.rectangle.position.x)
}
if (this.rectangle.position.y > calcPoint.y) {
calcPoint.y = this.rectangle.position.y
}
if (rectP2.x < calcPoint.x + size.x) {
calcPoint.x = rectP2.x - size.x
}
if (rectP2.y < calcPoint.y + size.y) {
calcPoint.y = rectP2.y - size.y
}

return calcPoint
}
}

您可以通过以下方式计算的元素大小:

let width = parseInt(window.getComputedStyle(element)['width'])
let height = parseInt(window.getComputedStyle(element)['height'])

我还可以建议使用 translate3d 属性来代替 left 和 top 位置的移动,因为它更有效率

关于javascript - 如何限制可拖动区域?它在顶部和左侧起作用,但在右侧和底部不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58644702/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com