兼容在不同浏览器不同分辨率下DIV高度自适应

本文介绍了一种使用JavaScript和jQuery实现的跨浏览器(包括IE、Firefox和Safari)的DIV高度自适应策略。通过检测浏览器类型和屏幕分辨率动态设置DIV的高度,以确保在不同环境下良好显示。另外,还提供了一种更简洁的方法,通过获取DOM元素的clientHeight直接计算高度,以适应页面布局。

在框架中嵌套了页面,页面中有些DIV,但都没有具体高度时,需要让一个div高度自适应时的解决办法

下面是笔者用js来判断不同浏览器的分辨率来动态设置的div高度

 var getDiv = document.getElementById("MainArea");
            getDiv.style.overflow = "auto";
            if (navigator.userAgent.indexOf("MSIE") > 0) {
                if ((document.body.scrollHeight == window.screen.height) && (document.body.scrollWidth == window.screen.width)) {
                    alert('全屏窗口');
                }
               
                if ((screen.height == "900") && (screen.width == "1440")) {
                    getDiv.style.height = "495px";
                }
                else {
                    getDiv.style.height = "365px";
                }
             
            }
            if (isFirefox = navigator.userAgent.indexOf("Firefox") > 0) {
                if ((screen.height == "900") && (screen.width == "1440")) {
                    getDiv.style.height = "465px";
                }
                else {
                    getDiv.style.height = "335px";
                }
                return "Firefox";
            }
            if (isSafari = navigator.userAgent.indexOf("Safari") > 0) {
                return "Safari";
            }
            if (isCamino = navigator.userAgent.indexOf("Camino") > 0) {
                return "Camino";
            }
            if (isMozilla = navigator.userAgent.indexOf("Gecko") > 0) {
                return "Gecko";
            }
  以上只设置了Ie和ff中,感觉较麻烦,故又重新换了思路直接获取客户端的高度(因为所有div均没有设置高度)

    $(document).ready(function () {
            var abodyHeight = document.getElementById("atbody").clientHeight;
            var aqueryHeight = document.getElementById("QueryArea").clientHeight;
            document.getElementById("MainArea").style.height = abodyHeight - aqueryHeight - 40;
        })

这样就行了!关于获取的DIV(id为MainArea)高度的计算,以下是从网上引用的,clitent的宽和高与直接设置的宽和高的差别大约为40px,这个是笔者测试过的

网页可见区域宽:document.body.clientWidth
网页可见区域高:document.body.clientHeight
网页可见区域宽:document.body.offsetWidth (包括边线的宽)
网页可见区域高:document.body.offsetHeight (包括边线的宽)
网页正文全文宽:document.body.scrollWidth
网页正文全文高:document.body.scrollHeight
网页被卷去的高:document.body.scrollTop
网页被卷去的左:document.body.scrollLeft
网页正文部分上:window.screenTop
网页正文部分左:window.screenLeft
屏幕分辨率的高:window.screen.height
屏幕分辨率的宽:window.screen.width
屏幕可用工作区高度:window.screen.availHeight
屏幕可用工作区宽度:window.screen.availWidth



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值