• js/jquery获取浏览器窗口可视区域高度和宽度以及滚动条高度实现代码


    获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。
    IE中,浏览器显示窗口大小只能以下获取: 代码如下复制代码 

    1 document.body.offsetWidth 
    2 document.body.offsetHeight

    在声明了DOCTYPE的浏览器中,可以用以下来获取浏览器显示窗口大小: 代码如下复制代码

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

    IE,FF,Safari皆支持该方法,opera虽支持该属性,但是返回的是页面尺寸;
    同时,除了IE以外的所有浏览器都将此信息保存在window对象中,可以用以下获取: 代码如下复制代码 

    1 window.innerWidth 
    2 window.innerHeight

    整个网页尺寸一般获得方法 代码如下复制代码

    1 document.body.scrollWidth 
    2 document.body.scrollHeight

    屏幕分辨率高度一般获得方法 代码如下复制代码

    1 window.screen.height 
    2 window.screen.width

    总结一下实例

    function getViewSizeWithoutScrollbar(){//不包含滚动条 
    return { 
    width : document.documentElement.clientWidth, 
    height: document.documentElement.clientHeight 
    } 
    } 
    function getViewSizeWithScrollbar(){//包含滚动条 
    if(window.innerWidth){ 
    return { 
    width : window.innerWidth, 
    height: window.innerHeight 
    } 
    }else if(document.documentElement.offsetWidth == document.documentElement.clientWidth){ 
    return { 
    width : document.documentElement.offsetWidth, 
    height: document.documentElement.offsetHeight 
    } 
    }else{ 
    return { 
    width : document.documentElement.clientWidth + getScrollWith(), 
    height: document.documentElement.clientHeight + getScrollWith() 
    } 
    } 
    }

    IE,FireFox 差异如下:
    IE6.0、FF1.06+: 

    1 clientWidth = width + padding 
    2 clientHeight = height + padding 
    3 offsetWidth = width + padding + border 
    4 offsetHeight = height + padding + border 
    5 IE5.0/5.56 clientWidth = width - border 
    7 clientHeight = height - border 
    8 offsetWidth = width 
    9 offsetHeight = height

    另附个人最常用的获取整页宽高的方法(需要jquery框架) 代码如下复制代码

    1 $(document).width() < $('body').width() ? $(document).width() : $('body').width(); 
    2 $(document).height() < $('body').height() ? $(document).height() : $('body').height();

    alert($(window).height()); //浏览器时下窗口可视区域高度
    alert($(document).height()); //浏览器时下窗口文档的高度
    alert($(document.body).height());//浏览器时下窗口文档body的高度
    alert($(document.body).outerHeight(true));//浏览器时下窗口文档body的总高度 包括border padding margin
    alert($(window).width()); //浏览器时下窗口可视区域宽度
    alert($(document).width());//浏览器时下窗口文档对于象宽度
    alert($(document.body).width());//浏览器时下窗口文档body的高度
    alert($(document.body).outerWidth(true));//浏览器时下窗口文档body的总宽度 包括border padding margin

    alert($(document).scrollTop()); //获取滚动条到顶部的垂直高度
    alert($(document).scrollLeft()); //获取滚动条到左边的垂直宽度 

    来源:http://www.jb51.net/article/32679.htm

  • 相关阅读:
    springmvc之SimpleUrlHandlerMapping非注解的方式实现url映射
    java之getMethods和getDeclaredMethods & Geoserver之ClassProperties
    geotools 21.2
    java之Method.invoke
    跟我学Python图像处理丨基于灰度三维图的图像顶帽运算和黑帽运算
    华为云SparkRTC面向低时延、大通量传输业务的技术探索
    浏览器、负载均衡 、进程内部层…那些你需要掌握的多级缓存
    家电上云后,智能家居如何构建场景化应用
    带你徒手完成基于MindSpore的CycleGAN实现
    二分查找:一种效率较高的查找方法
  • 原文地址:https://www.cnblogs.com/pengchengzhong/p/6050657.html
Copyright © 2020-2023  润新知