北京尚网汇智科技有限公司
您当前所在的位置:尚网汇智网站建设 > 前端语言JS技术 > 文章详细
网站建设知识
NEWS
联系我们
  • 网站建设服务电话
  • 400-883-2887
  • 公司地址:北京市昌平科技园区创意大厦2-806
  • 服务项目
    高端网站建设
    移动/微信网站建设
    手机APP开发
    OA/ERP业务系统开发
    网站维护托管
    CMS模板制作

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

    发布时间:2015-08-24 09:34:43

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

    获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。

    IE中,浏览器显示窗口大小只能以下获取:
    代码如下:

    document.body.offsetWidth
    document.body.offsetHeight

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

    document.documentElement.clientWidth
    document.documentElement.clientHeight

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

    window.innerWidth
    window.innerHeight

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

    document.body.scrollWidth
    document.body.scrollHeight

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

    window.screen.height
    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+:
    代码如下:

    clientWidth = width + padding
    clientHeight = height + padding
    offsetWidth = width + padding + border
    offsetHeight = height + padding + border
    IE5.0/5.5:
    clientWidth = width - border
    clientHeight = height - border
    offsetWidth = width
    offsetHeight = height

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

    $(document).width() < $('body').width() ? $(document).width() : $('body').width();
    $(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()); //获取滚动条到左边的垂直宽度


    文章出自:北京网站建设公司-尚网汇智 https://www.net2006.com 如转载请注明出处!
    咨询服务热线
    400-883-2887
    客服电话:400-883-2887  传真:010-51654992  E-mail:support@net2006.com
    本站设计已受版权保护,任何公司及个人不得复制,违者将依法追究责任,特此声明。

    Copyright © 2005-2018 北京尚网汇智科技有限公司 版权所有 京ICP备13031271号
    查找内容: