AJax技术

原生JS 获取浏览器、窗口、元素等尺寸总结

字号+ 作者:H5之家 来源:H5之家 2015-11-18 10:25 我要评论( )

本文我们部结了原生JS 获取浏览器、窗口、元素等尺寸的方法及注意事项,JS获取各种浏览器窗口大小的方法。

本文我们部结了原生JS 获取浏览器、窗口、元素等尺寸的方法及注意事项,JS获取各种浏览器窗口大小的方法。

一、通过浏览器获得屏幕的尺寸

screen.width
screen.height

screen.availHeight //获取去除状态栏后的屏幕高度
screen.availWidth  //获取去除状态栏后的屏幕高度

二、获取浏览器窗口内容的尺寸

//高度
window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight

//宽度
window.innerWidth || document.documentElement.clientWidth || document.body.clientWidht

/ *
  * window.innerHeight   FF/CH 支持,获取窗口尺寸。
  * document.documentElement.clientHeight    IE/CH支持
  * document.body.client    通过body元素获取内容的尺寸

* /


三、滚动条支持的差异性

不进行任何滚动条更改的页面,Firefox/IE 默认认为HTML元素具有滚动条属性。而body不具有。
但Chrome 则认为body是具有滚动条属性的。
因此兼容性的写法是:

document.documentElement.scrollTop || document.body.scrollTop


四、获取元素的尺寸

elemnt.offsetWidth
elemnt.offsetHeight

// 仅IE5不支持,放心使用吧

说明图:


  * offsetWidth 可以获取元素的高度尺寸,包括:width + padding[left,right] + border[left,right]
  * offsetHeight 可以获取元素的宽度尺寸,包括:height + padding[top,bottom] + bottom[top,bottom]

五、元素的偏移属性

element.offsetTop  //获取元素与其偏移参考父元素顶部的间隔距离
element.offsetLeft  //获取元素与其偏移参考父元素左边的间隔距离
element.offsetParent  //获取当前元素的参考父元素


*offsetTop 可以获取元素距其上一级的偏移参考父元素顶部的距离。包括:margin[top] + top
*offsetLeft 可以获取元素距其上一级的偏移参考父元素左边的距离。包括:margin[left] + left
*注意的是offsetParent在IE6/7,与IE8/FF/CH中存在兼容性问题:

在FF/Chrome/IE8+ :
如果当前元素有定位,则偏移参考父元素是其上一级的最近的那个定位元素。
如果当前元素没有定位,则默认以body为最终的参考父元素。

在IE6/7:
不论有没有定位,其偏移参考父元素都是其上一级的父元素。

总的来说:
不论是FF/Chrome还是IE,最终的参考父元素都是body元素, 因此兼容的方法就是获取当前元素到body元素的偏移位置值。

兼容性写法

function getOffestValue(elem){

    var Far = null;
    var topValue = elem.offsetTop;
    var leftValue = elem.offsetLeft;
    var offsetFar = elem.offsetParent;

    while(offsetFar){
        alert(offsetFar.tagName)
        topValue += offsetFar.offsetTop;
        leftValue += offsetFar.offsetLeft;
        Far = offsetFar;
        offsetFar = offsetFar.offsetParent;
    }
    return {'top':topValue,'left':leftValue,'Far':Far}
}

/*
  * top 当前元素距离body元素顶部的距离。
  * left 当前元素距离body元素左侧的距离。
  * Far  返回最终的参考父元素。
*/



JS获取各种浏览器窗口大小的方法

常用:
JS 获取浏览器窗口大小

// 获取窗口宽度
if (window.innerWidth)
winWidth = window.innerWidth;
else if ((document.body) && (document.body.clientWidth))
winWidth = document.body.clientWidth;
// 获取窗口高度
if (window.innerHeight)
winHeight = window.innerHeight;
else if ((document.body) && (document.body.clientHeight))
winHeight = document.body.clientHeight;
// 通过深入 Document 内部对 body 进行检测,获取窗口大小
if (document.documentElement && document.documentElement.clientHeight && document.documentElement.clientWidth)
{
winHeight = document.documentElement.clientHeight;
winWidth = document.documentElement.clientWidth;
}


详细:
关于获取各种浏览器可见窗口大小:
<script>
function getInfo()
{
var s = "";
s = " 网页可见区域宽:" document.body.clientWidth;
s = " 网页可见区域高:" document.body.clientHeight;
s = " 网页可见区域宽:" document.body.offsetWidth " (包括边线和滚动条的宽)";
s = " 网页可见区域高:" document.body.offsetHeight " (包括边线的宽)";
s = " 网页正文全文宽:" document.body.scrollWidth;
s = " 网页正文全文高:" document.body.scrollHeight;
s = " 网页被卷去的高(ff):" document.body.scrollTop;
s = " 网页被卷去的高(ie):" document.documentElement.scrollTop;
s = " 网页被卷去的左:" document.body.scrollLeft;
s = " 网页正文部分上:" window.screenTop;
s = " 网页正文部分左:" window.screenLeft;
s = " 屏幕分辨率的高:" window.screen.height;
s = " 屏幕分辨率的宽:" window.screen.width;
s = " 屏幕可用工作区高度:" window.screen.availHeight;
s = " 屏幕可用工作区宽度:" window.screen.availWidth;

s = " 你的屏幕设置是 " window.screen.colorDepth " 位彩色";
s = " 你的屏幕设置 " window.screen.deviceXDPI " 像素/英寸";
//alert (s);
}
getInfo();
</script>

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • Ajax(Asynchronous JavaScript + XML)的定义

    Ajax(Asynchronous JavaScript + XML)的定义

    2016-01-17 17:25

  • WordPress中利用AJAX异步获取评论用户头像的方法

    WordPress中利用AJAX异步获取评论用户头像的方法

    2016-01-15 14:13

  • 原生ajax调用数据实例讲解

    原生ajax调用数据实例讲解

    2016-01-15 14:09

  • 浏览器脚本系列教程

    浏览器脚本系列教程

    2016-01-15 12:24

网友点评