针对我们获取元素在页面中的位置的问题,我们还是用老师一峰老师的方法来解决吧

下面上HTML代码

<div class="left_footer">
   <p class="p1" data-num="1" ref="data" @mouseenter="mOver($event)" @mouseleave="mOut($event)">上</p>
   <p data-num="2" ref="data" @mouseenter="mOver($event)" @mouseleave="mOut($event)">右</p>
   <p data-num="3" ref="data" @mouseenter="mOver($event)" @mouseleave="mOut($event)">左</p>
</div>

我拿上面的代码来简单举下例css代码我就不上了,在这里不影响

在上面我需要获取到对应的DOM元素就可以进行相关的函数操作了

这里的话比如说获取第一个p元素

var element = document.querySelector(".left_footer .p1");

接下来直接将element传入函数即可

下面我们直接上函数代码:

  其中的element的意思是代表的是我们需要操作的这个节点,我们只需要把对应的节点传入即可

  函数的返回值就是我们所得到的距离值

function getElementTop(element) {
      var actualTop = element.offsetTop;    //这是获取元素距父元素顶部的距离
      var current = element.offsetParent;   //这是获取父元素
      while (current !== null) {      //当它上面有元素时就继续执行
        actualTop += current.offsetTop;   //这是获取父元素距它的父元素顶部的距离累加起来
        current = current.offsetParent;  //继续找父元素
      }
      return actualTop;   
    },

 以上就是如何获取顶部的值,那么获取距左边的距离道理也是一样的,这里我就不在多说了哈

posted on 2020-02-07 10:06  镇宁  阅读(10572)  评论(0编辑  收藏  举报