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高)
  • 相关阅读:
    计算机网络 基础 1
    JAVA 基础之 多线程
    HashMap 多线程处理之 FailFast机制:
    Struts2
    JAVA 由浅及深之 Servlet
    Servlet 会话技术 , Session 及 Cookie 详解
    JAVA 设计模式 : 单例模式
    JAVA 基础之 序列化 Serializable
    代理模式 及 实现AOP 拦截机制
    web.xml 文件详解 及 listener、 filter、servlet 加载顺序
  • 原文地址:https://www.cnblogs.com/asqq/p/2833444.html
Copyright © 2011-2022 走看看