精确定位 以及js实现拖动

下文中的所有event都指的是跨浏览器的event对象,即DOM事件的event,IE事件为window.event.

 

事件的各种坐标

 

1. clientX clientY

event.clientX;    

event.clientY;

鼠标相对于浏览器窗口可视区域的水平,垂直距离。(可视区域不包括工具栏和滚动条)

注:如果鼠标不动,滚动滚轮,再次点击,值不变

2. pageX  pageY

event.pageX;

event.pageY;

页面坐标,相对于文档的坐标,左上角为(0,0),左、上为负,右、下为正,

注:pageX=clientX+scrollLeft  pageY=clientY+scrollTop

也就是说: pageX 和 pageY获取的是相对文档高度,可以理解为距body最左上角的位值

3. screenX , screenY

event.screenX;

event.screenY;

相对于屏幕的坐标,包括浏览器工具栏,包括工具栏上方的任何其他内容

4. offsetX offsetY

event.screenX;

event.screenY;

鼠标光标相对于目标元素边界的水平和垂直坐标(如果不存在任何容器,例如它是window上的监听事件,那么它和e.pageX , e.pageY是等效的。)

2、元素大小

DOM中没有规定如何确定页面中元素的大小,IE引入了一些属性,所以width和height是基于IE盒模型,即外盒大小=内容+margin 

元素的可见大小由其高度/宽度决定,包括所有内边距,滚动条,和边框大小。

1. 偏移量 offset dimension

 

element.offsetHeight:元素在垂直方向上占用的空间大小,包括元素高度(内容+padding+border)和可见的水平滚动条的高度

element.offsetWidth:元素在水平方向上占用的空间大小,包括元素宽度(内容+padding+border)和可见的垂直滚动条的高度

element.offsetLeft:元素的左外边框距离其包含元素的左内边框的像素距离

element.offsetTop:元素的上外边框距离其包含元素的上内边框见的像素距离

 

offsetParent: 距离最近的拥有大小的祖先节点 

下面代码将算出某个元素在页面上的偏移量,思路是将该元素的offsetLeft和offsetTop与其offsetParent的对应元素相加,一直循环至根节点,就可以得到一个基本准确的值:

function getElementOffset(element) {

    var offset = { 

        acturalLeft: element.offsetLeft,

        acturalTop: element.offsetTop

    }   

    var current = element.offsetParent;

    while(current != null) {  

        offset.acturalLeft += current.offsetLeft;

        offset.acturalTop += current.offsetTop;

        current = current.offsetParent;//让current等于其offsetParent,继续循环,直到current=null,即循环到了根元素,结束循环

    }

    return offset;

}

注意: 

所有上述偏移量都是只读的,并且每次访问它们都需要重新计算,因此,应该避免重复访问这些属性;如果要重复使用它们,可以将其保存在局部变量中,提高性能!

2、客户区大小 clientWidth和clientHeight

客户区大小指的是元素内容及其内边距所占据的大小。不包括滚动条

element.clientWidth;// = 内容+左右内边距

element.clientHeight;//= 内容+上下内边距

 

3、滚动大小 scroll dimension

滚动大小指的是包含滚动内容的元素的大小

element.scrollHeight;//没有滚动条的情况下,元素内容的总高度

element.scrollWidth;//没有滚动条的情况下,元素内容的总宽度

element.scrollLeft;//被隐藏在内容区域左侧的像素数

element.scrollTop;//被隐藏在内容区上方的像素数



	
		
		
		
		
	
	
		

 

你可能感兴趣的:(js)