当前位置: 首页 > 知识库问答 >
问题:

如何获取div左上角的坐标

宫晟
2023-03-14

我试图在父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,但它不起作用。

共有1个答案

狄玮
2023-03-14

如果我理解正确,您希望在拖动实际可拖动对象时获得该对象的坐标,那么也许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使用坐标系统作为左上角。我需要帮助将坐标从左下转换为左上角 更新我的问题 如果你不理解我的问题,如果没