我试图在父div内获得可拖动div的左上角的坐标。我可以在父div中获取鼠标的坐标,这是通过一个onmousemove
标签完成的。我想知道是否有任何类似的标记,例如onmobile
来获取div的坐标
<!DOCTYPE html>
<html>
<style>
#parent {
width: 148mm;
height: 160mm;
background-color: yellow;
position: relative;
<!--border: 3px solid #e5e5e5;-->
}
#mydiv {
position: absolute;
z-index: 9;
text-align: center;
border: 1px solid #d3d3d3;
}
#mydivheader {
padding: 10px;
cursor: move;
z-index: 10;
}
</style>
<body>
<div id="parent" style="float:left" onmouseout="clearCoor()">
<div id="mydiv">
<div id="mydivheader" onmove="showCoords(event)"><img src="bc.png" alt="image"></div>
</div>
</div>
<p id="demo"></p>
<script>
//Make the DIV element draggagle:
dragElement(document.getElementById("mydiv"));
function dragElement(elmnt) {
var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
if (document.getElementById(elmnt.id + "header")) {
/* if present, the header is where you move the DIV from:*/
document.getElementById(elmnt.id + "header").onmousedown = dragMouseDown;
} else {
/* otherwise, move the DIV from anywhere inside the DIV:*/
elmnt.onmousedown = dragMouseDown;
}
function dragMouseDown(e) {
e = e || window.event;
e.preventDefault();
// get the mouse cursor position at startup:
pos3 = e.clientX;
pos4 = e.clientY;
document.onmouseup = closeDragElement;
// call a function whenever the cursor moves:
document.onmousemove = elementDrag;
}
function elementDrag(e) {
e = e || window.event;
e.preventDefault();
// calculate the new cursor position:
pos1 = pos3 - e.clientX;
pos2 = pos4 - e.clientY;
pos3 = e.clientX;
pos4 = e.clientY;
let parentElement = elmnt.parentElement;
if(elmnt.offsetTop < 0){elmnt.style.top = "0px"; return;}
if(elmnt.offsetTop > (parentElement.offsetHeight - elmnt.offsetHeight)) {
elmnt.style.top = (parentElement.offsetHeight - elmnt.offsetHeight) + "px";
return;
}
if(elmnt.offsetLeft < 0){elmnt.style.left = "0px";return}
if(elmnt.offsetLeft > (parentElement.offsetWidth - elmnt.offsetWidth)){
elmnt.style.left = (parentElement.offsetWidth - elmnt.offsetWidth) + "px";
return;
}
// set the element's new position:
elmnt.style.top = (elmnt.offsetTop - pos2) + "px";
elmnt.style.left = (elmnt.offsetLeft - pos1) + "px";
}
function closeDragElement() {
/* stop moving when mouse button is released:*/
document.onmouseup = null;
document.onmousemove = null;
}
}
function showCoords(event) {
var x = event.clientX;
var y = event.clientY;
var coor = "X coords: " + x + ", Y coords: " + y;
document.getElementById("demo").innerHTML = coor;
}
function clearCoor() {
document.getElementById("demo").innerHTML = "";
}
</script>
</body>
</html>
我使用标签onmobile
,但它不起作用。
如果我理解正确,您希望在拖动实际可拖动对象时获得该对象的坐标,那么也许getBoundingClientRect就是您想要的?
我修改了原始HTML,以消除元素上对ID的需要,因为当您开始将字符串连接到ID以识别元素时,事情有点不对劲。还有其他更好的方法来识别DOM元素,也许最有用的是querySelector和querySelectorAll,为了简洁起见,这两种方法都在下面用一个箭头函数以简写表示。
getBoundingClientRect
函数也被缩写为box
,它在show Cobow
函数中被称为let obj=box(event.target);
其中event.target
派生自外部注册的事件侦听器,如下所示:
q('.draggable > div').addEventListener('mousemove',showCoords); // the event is implicitly applied...
在本例中,您需要的事件实际上是onmousemove
,而不是onmousemove
——在这里,再次分配一个外部侦听器,而不是旧的内联类型onmousemove=func(e)
等
const box=(n)=>n.getBoundingClientRect();
const q=(e,n=document)=>n.querySelector(e);
const qa=(e,n=document)=>n.querySelectorAll(e);
qa('.draggable').forEach(el=>dragElement(el));
q('.draggable > div').addEventListener('mousemove',showCoords);
q('.parent').addEventListener('mouseout',clearCoor);
function dragElement(n) {
var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
let child=q('div',n);
if ( child ) child.onmousedown = dragMouseDown;
else n.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;
let parentElement = n.parentNode;
if( n.offsetTop < 0 ){ n.style.top = "0px"; return; }
if( n.offsetTop > ( parentElement.offsetHeight - n.offsetHeight ) ){
n.style.top = (parentElement.offsetHeight - n.offsetHeight) + "px";
return;
}
if( n.offsetLeft < 0 ){ n.style.left = "0px"; return }
if( n.offsetLeft > ( parentElement.offsetWidth - n.offsetWidth ) ){
n.style.left = ( parentElement.offsetWidth - n.offsetWidth ) + "px";
return;
}
n.style.top = (n.offsetTop - pos2) + "px";
n.style.left = (n.offsetLeft - pos1) + "px";
}
function closeDragElement() {
document.onmouseup = null;
document.onmousemove = null;
}
}//close parent function `dragElement`
function showCoords(event) {
let obj=box(event.target);
let str=`
X:${event.clientX}
Y:${event.clientY}
<br />
Top-Left:${obj.top.toFixed(2)}px, ${obj.left.toFixed(2)}px
Top-Right:${obj.top.toFixed(2)}px, ${obj.right.toFixed(2)}px
<br />
Bttm-Left:${obj.bottom.toFixed(2)}px, ${obj.left.toFixed(2)}px
Bttm-Right:${obj.bottom.toFixed(2)}px, ${obj.right.toFixed(2)}px`;
q("#demo").innerHTML = str;
}
function clearCoor() {
q("#demo").innerHTML = "";
}
.parent{
width: 148mm;
height: 160mm;
background-color: yellow;
position: relative;
border: 3px solid #e5e5e5;
}
.draggable{
position: absolute;
z-index: 9;
text-align: center;
border: 1px solid #d3d3d3;
}
.draggable > div{
padding: 10px;
cursor: move;
z-index: 10;
}
#demo{
min-height:3rem;
font-family:monospace;
font-size:smaller;
}
<p id='demo'></p>
<div class='parent'>
<div class='draggable'>
<div>
<img src='//placekitten.com/200/200?image=15' alt='image' />
</div>
</div>
</div>
本文向大家介绍js实现获取div坐标的方法,包括了js实现获取div坐标的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js实现获取div坐标的方法。分享给大家供大家参考,具体如下: html中最常使用的控件就是div了,那么如何获取div的坐标呢? 如下方法可以实现: com.whuang.hsj.divCoordinate()方法介绍 功能:返回div坐标; 参数:div对象或d
根据坐标系,如果只给定矩形的中心坐标以及宽度和高度,您将如何确定矩形的左上角坐标? 例如,矩形的中心坐标是(40,40),矩形的宽度为90,高度为60。
如何获得旋转矩形的角坐标(以矩形为中心)? 我已经尝试了以下链接中的所有解决方案,但似乎没有任何运气。 将一个点绕另一个点旋转(2D) 找到给定中心点和旋转的旋转矩形的角 https://game dev . stack exchange . com/questions/86755/how-to-calculate-corner-positions-marks-of-a-rotated-tilte
问题内容: 如何仅将角半径设置为仅左下角,右下角和左上角textview? 此代码创建两个矩形。我不知道为什么。 问题答案: 您只需要遮罩该图层,如下所示: 对于Swift 3 : 较低版本:
我正在做一个简单的模拟,并且在寻找一个旋转的、大小怪异的ImageView节点的X和Y坐标时遇到了很多麻烦。(蓝色的部分是前面) 目标是在旋转后找出相对于imageView指向的方向的XY坐标。我可以找到imageView相对于其起始位置的角度,但我不知道如何获得imageView相对于该角度的XY坐标。从那以后。setRotate(angle)方法不会更改imageView的X和Y位置,我应该如
我正在使用PDFBOX和itextSharp dll并处理pdf。这样我就可以得到矩形内文本的文本坐标。矩形坐标是使用itextsharp.dll.基本上我从itextsharp.dll获得矩形坐标,其中itextSharp使用坐标系统作为左下。我从PDFBOX获得pdf页面文本,其中PDFBOX使用坐标系统作为左上角。我需要帮助将坐标从左下转换为左上角 更新我的问题 如果你不理解我的问题,如果没