zoukankan      html  css  js  c++  java
  • js获取窗口大小

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

     1 // 获取窗口宽度
     2 if (window.innerWidth)
     3 winWidth = window.innerWidth;
     4 else if ((document.body) && (document.body.clientWidth))
     5 winWidth = document.body.clientWidth;
     6 // 获取窗口高度
     7 if (window.innerHeight)
     8 winHeight = window.innerHeight;
     9 else if ((document.body) && (document.body.clientHeight))
    10 winHeight = document.body.clientHeight;
    11 // 通过深入 Document 内部对 body 进行检测,获取窗口大小
    12 if (document.documentElement && document.documentElement.clientHeight && document.documentElement.clientWidth)
    13 {
    14 winHeight = document.documentElement.clientHeight;
    15 winWidth = document.documentElement.clientWidth;
    16 }

    详细:
    关于获取各种浏览器可见窗口大小:

     1 <script>
     2 function getInfo()
     3 {
     4 var s = "";
     5 s = " 网页可见区域宽:" document.body.clientWidth;
     6 s = " 网页可见区域高:" document.body.clientHeight;
     7 s = " 网页可见区域宽:" document.body.offsetWidth " (包括边线和滚动条的宽)";
     8 s = " 网页可见区域高:" document.body.offsetHeight " (包括边线的宽)";
     9 s = " 网页正文全文宽:" document.body.scrollWidth;
    10 s = " 网页正文全文高:" document.body.scrollHeight;
    11 s = " 网页被卷去的高(ff):" document.body.scrollTop;
    12 s = " 网页被卷去的高(ie):" document.documentElement.scrollTop;
    13 s = " 网页被卷去的左:" document.body.scrollLeft;
    14 s = " 网页正文部分上:" window.screenTop;
    15 s = " 网页正文部分左:" window.screenLeft;
    16 s = " 屏幕分辨率的高:" window.screen.height;
    17 s = " 屏幕分辨率的宽:" window.screen.width;
    18 s = " 屏幕可用工作区高度:" window.screen.availHeight;
    19 s = " 屏幕可用工作区宽度:" window.screen.availWidth;
    20 s = " 你的屏幕设置是 " window.screen.colorDepth " 位彩色";
    21 s = " 你的屏幕设置 " window.screen.deviceXDPI " 像素/英寸";
    22 //alert (s);
    23 }
    24 getInfo();
    25 </script>

    在我本地测试当中:
    在IE、FireFox、Opera下都可以使用

    document.body.clientWidth
    document.body.clientHeight

    即可获得,很简单,很方便。
    而在公司项目当中:
    Opera仍然使用

    1 document.body.clientWidth
    2 document.body.clientHeight

    可是IE和FireFox则使用

    1 document.documentElement.clientWidth
    2 document.documentElement.clientHeight


    原来是W3C的标准在作怪啊

    1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


    如果在页面中添加这行标记的话 在IE中:

    document.body.clientWidth ==> BODY对象宽度
    document.body.clientHeight ==> BODY对象高度
    document.documentElement.clientWidth ==> 可见区域宽度
    document.documentElement.clientHeight ==> 可见区域高度

    在FireFox中:

    document.body.clientWidth ==> BODY对象宽度
    document.body.clientHeight ==> BODY对象高度
    document.documentElement.clientWidth ==> 可见区域宽度
    document.documentElement.clientHeight ==> 可见区域高度


    在Opera中:

    document.body.clientWidth ==> 可见区域宽度
    document.body.clientHeight ==> 可见区域高度
    document.documentElement.clientWidth ==> 页面对象宽度(即BODY对象宽度加上Margin宽)
    document.documentElement.clientHeight ==> 页面对象高度(即BODY对象高度加上Margin高)


    而如果没有定义W3C的标准,则
    IE为:

    document.documentElement.clientWidth ==> 0
    document.documentElement.clientHeight ==> 0


    FireFox为:

    document.documentElement.clientWidth ==> 页面对象宽度(即BODY对象宽度加上Margin宽)
    document.documentElement.clientHeight ==> 页面对象高度(即BODY对象高度加上Margin高)


    Opera为:

    document.documentElement.clientWidth ==> 页面对象宽度(即BODY对象宽度加上Margin宽)
    document.documentElement.clientHeight ==> 页面对象高度(即BODY对象高度加上Margin高)
  • 相关阅读:
    C语言中scanf()的用法
    Android学习笔记——Day3
    Android学习笔记——Day6
    Android学习笔记——Day5
    Android学习笔记——Day4
    Android学习笔记——Day2
    一个计时器按钮
    直方图均衡
    拉普拉斯算子进行图像边缘提取
    在jframe上显示超大号的文字
  • 原文地址:https://www.cnblogs.com/asqq/p/2833444.html
Copyright © 2011-2022 走看看