>웹 프론트엔드 >JS 튜토리얼 >창 position_javascript 기술과 관련된 요소를 얻기 위한 Node.js 구현 코드

창 position_javascript 기술과 관련된 요소를 얻기 위한 Node.js 구현 코드

WBOY
WBOY원래의
2016-05-16 16:35:031209검색

JS는 offsetTop, offsetLeft 및 요소의 기타 속성을 가져옵니다

obj.clientWidth //요소의 너비를 가져옵니다

obj.clientHeight //요소의 높이
obj.offsetLeft //부모 요소를 기준으로 요소의 왼쪽
obj.offsetTop //상위 요소를 기준으로 한 요소의 상단
obj.offsetWidth //요소의 너비
obj.offsetHeight //요소 높이

차이:

clientWidth = 너비 패딩
clientHeight = 높이 패딩
offsetWidth = 너비 패딩 테두리
offsetHeight = 너비 패딩 테두리
오프셋이 테두리 너비보다 큽니다

//获取元素的纵坐标(相对于窗口)
function getTop(e){
  var offset=e.offsetTop;
  if(e.offsetParent!=null) offset+=getTop(e.offsetParent);
  return offset;
}
//获取元素的横坐标(相对于窗口)
function getLeft(e){
  var offset=e.offsetLeft;
  if(e.offsetParent!=null) offset+=getLeft(e.offsetParent);
  return offset;
}

이전에 JS에서 요소 위치를 가져오는 방법에 대한 기사를 작성한 적이 있습니다. JS는 offsetTop, offsetLeft 및 요소의 기타 속성을 가져오며 offsetTop 및 offsetLeft 속성을 통해 창을 기준으로 요소의 위치를 ​​가져올 수 있습니다. 하지만 offsetTop 및 offsetLeft 속성은 상위 요소를 기준으로 위치가 지정되며 일반적으로 위치를 얻어야 하는 요소가 가장 바깥쪽 레이어에 없으므로 상위 요소의 오프셋 관련 속성을 순회하는 것이 필수적입니다. 그러면 효율성이 문제가 됩니다.

//获取元素的纵坐标(相对于窗口)
function getTop(e){
var offset=e.offsetTop;
if(e.offsetParent!=null) offset+=getTop(e.offsetParent);
return offset;
}
//获取元素的横坐标(相对于窗口)
function getLeft(e){
var offset=e.offsetLeft;
if(e.offsetParent!=null) offset+=getLeft(e.offsetParent);
return offset;
}

다행히도 브라우저는 해당 인터페이스 getBoundingClientRect를 제공했습니다. 이 방법은 IE 브라우저에 처음 등장했으며 이후 브라우저에서도 이 방법을 지원했으며 IE는 왼쪽, 위쪽, 아래쪽 요소 속성만 가져올 수 있습니다. , right 및 최신 브라우저에서는 요소의 너비와

도 얻을 수 있습니다.

Chrome Firefox (Gecko) Internet Explorer Opera Safari
1.0 3.0 (1.9) 4.0 (Yes) 4.0

여기서 주목해야 할 점은 하단은 창 하단을 기준으로 한 CSS의 위치 하단이 아니라 요소 하단과 창 상단 사이의 거리라는 것입니다. 요소의 가장 오른쪽 부분과 창의 왼쪽 부분 사이의 거리입니다.

var box = document.getElementById("box");
var pos = box.getBoundingClientRect();
box.innerHTML = "top:"+pos.top +
  "left:"+pos.left +
  "bottom:"+pos.bottom +
  "right:"+pos.right +
  "width:"+pos.width +
  "height:"+pos.height

원본 기사, 재인쇄 시 명시해 주세요: 프론트 엔드 개발에서 재인쇄

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.