在框架中嵌套了页面,页面中有些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