我有一个从窗口右边的固定位置开始的div,但是它是可拖动的(使用javascript)和大小(使用css)。问题是,如果首先调整div的大小(通过抓取右下角),它将无法适当地调整大小。它将保持其固定的位置从右边,然后它将增长或收缩从左侧。但是,如果首先拖动div,则调整大小将按预期工作。以下是div的当前css属性:
#resize {
position: fixed;
right: 30px;
height: 90px;
width: 90px;
background-color: blue;
resize: both;
overflow: auto;
}
演示:
https://jsfiddle.net/mravdo52/2/
我试过各种解决办法。由于div的移动似乎使resize
正常工作,所以在加载元素后,我尝试将div移动一个像素,但这不起作用,因为我认为在元素的加载、javascript的执行和css的加载之间存在时间问题。随后,我尝试使用jQuery promise()
和queue()
先应用css,然后移动元素,但它们也不起作用。我也尝试过使用jQuery UI resizable()
,但这似乎根本没有调整大小。在这一点上,我没有任何想法,希望能提供任何帮助。
发布于 2018-11-04 23:41:01
CSS唯一的解决方案:--您只需要最初将左边分配给固定位置的div。
解决方案解释:当它拖动元素后工作的原因是,因为它申请的是一个左位置,所以我们可以在拖动元素之前给出左位置,这样它就能工作了!
第一次尝试给left: auto/initial/inherit
,但不起作用。因此,您可以给出如下内容:左侧: calc(100% -120 So );
(120 of表示正确位置30 of和div 90 of宽度之和)
#resize {
position: fixed;
right: 30px;
left: calc(100% - 120px);
height: 90px;
width: 90px;
background-color: blue;
resize: both;
overflow: auto;
min-width: 90px;
min-height: 90px;
max-width: calc(100% - 60px);
max-height: calc(100vh - 50px);
}
dragElement(document.getElementById("resize"));
function dragElement(elmnt) {
var pos1 = 0,
pos2 = 0,
pos3 = 0,
pos4 = 0;
if (document.getElementById("drag")) {
document.getElementById("drag").onmousedown = dragMouseDown;
} else {
elmnt.onmousedown = dragMouseDown;
}
function dragMouseDown(e) {
e = e || window.event;
e.preventDefault();
pos3 = e.clientX;
pos4 = e.clientY;
document.onmouseup = closeDragElement;
document.onmousemove = elementDrag;
}
function elementDrag(e) {
e = e || window.event;
e.preventDefault();
pos1 = pos3 - e.clientX;
pos2 = pos4 - e.clientY;
pos3 = e.clientX;
pos4 = e.clientY;
elmnt.style.top = (elmnt.offsetTop - pos2) + "px";
elmnt.style.left = (elmnt.offsetLeft - pos1) + "px";
}
function closeDragElement() {
document.onmouseup = null;
document.onmousemove = null;
}
}
#resize {
position: fixed;
right: 30px;
height: 90px;
width: 90px;
background-color: blue;
resize: both;
overflow: auto;
min-width: 90px;
min-height: 90px;
max-width: calc(100% - 60px);
max-height: calc(100vh - 50px);
}
#drag {
background-color: red;
height: 20px;
}
<div id="resize">
<div id="drag">
</div>
</div>
https://stackoverflow.com/questions/53144373
复制相似问题