在ajax中经常需要对元素的位置进行精确的定位,此时不仅需要获取元素自身的大小位置等属性。还需要知道页面、浏览器、滚动条等的长度和宽度。因为浏览器的兼容问题,如果使用javascript获取这些数值是一个相当痛苦的过程。好在JQuery提供了简单优雅,并且兼容的解决方法。
获取浏览器和页面文档的宽度和高度
1 //获取浏览器显示区域的高度
2 $(window).height();
3 //获取浏览器显示区域的宽度
4 $(window).width();
5
6 //获取页面的文档高度
7 $(document.body).height();
8 //获取页面的文档宽度
9 $(document.body).width();
2 $(window).height();
3 //获取浏览器显示区域的宽度
4 $(window).width();
5
6 //获取页面的文档高度
7 $(document.body).height();
8 //获取页面的文档宽度
9 $(document.body).width();
获取滚动条的位置
1 //获取滚动条到顶部的垂直高度
2 $(document).scrollTop();
3 //获取滚动条到左边的垂直宽度
4 $(document).scrollLeft();
2 $(document).scrollTop();
3 //获取滚动条到左边的垂直宽度
4 $(document).scrollLeft();
计算位置和偏移量
offset方法是一个很有用的方法,它返回包装集中第一个元素的偏移信息。默认情况下是相对body的偏移信息。结果包含top和left两个属性。
offset(options, results)
options.relativeTo 指定相对计算偏移位置的祖先元素。这个元素应该是relative或absolute定位。省略则相对body。
options.scroll 是否把滚动条计算在内,默认TRUE
options.padding 是否把padding计算在内,默认false
options.margin 是否把margin计算在内,默认true
options.border 是否把边框计算在内,默认true