您现在的位置是:网站首页> 编程资料编程资料

HTML文档类型详解 推荐_HTML/Xhtml_网页制作_

2023-11-12 337人已围观

简介 昨天给添加了在线测试效果!打开后发现JS弹出框位置和效果不对!但是我在我本地测试是没问题的!仔细检查后发现原来是由于博客园的HTML文档类型和我的不一样。

我的是:

博客园:

关于HTML文档类型参考:http://i.wanz.im/2010/05/28/why_doctype_html/

检查发现JS在获取当前页面可视大小,和页面滚动位置有差别!
在页面包含一个2000*2000的DIV是IE和Chrome在不同HTML文档类型测试整理数据如下:
标准:
特殊:

当HTML中未添加HTML文档类型时,默认为特殊模式!

Chrome标准Chrome特殊IE标准IE特殊
document.body.clientTop;0002
document.body.clientLeft;0002
document.body.clientWidth;473473471471
document.body.clientHeight;20006252000604
document.body.scrollTop;2242890255
document.body.scrollLeft;3153880278
document.body.scrollWidth;2005200520052010
document.body.scrollHeight;2010201020002005
document.body.offsetTop;0000
document.body.offsetLeft;0000
document.body.offsetWidth;473473471492
document.body.offsetHeight;200020002000625
document.documentElement.clientTop;0000
document.documentElement.clientLeft;0000
document.documentElement.clientWidth;4734734710
document.documentElement.clientHeight;62520106040
document.documentElement.scrollTop;001990
document.documentElement.scrollLeft;002410
document.documentElement.scrollWidth;200520052005492
document.documentElement.scrollHeight;201020102010625
document.documentElement.offsetTop;0000
document.documentElement.offsetLeft;0000
document.documentElement.offsetWidth;473473492492
document.documentElement.offsetHeight;20102010625 625

分析:

页面总宽度:document.body.scrollWidth;
页面总高度:document.body.scrollHeight;
Chrome页面位置:document.body.scrollTop; document.body.scrollLeft;
Chrome标准页面可视区域:document.documentElement.clientWidth; document.documentElement.clientHeight;
Chrome特殊页面可视区域:document.body.clientWidth; document.body.clientHeight;
IE标准页面位置:document.documentElement.scrollTop; document.documentElement.scrollLeft;
IE标准页面可视区域:document.documentElement.clientWidth; document.documentElement.clientHeight;
IE特殊页面位置:document.body.scrollTop; document.body.scrollLeft;
IE特殊页面可视区域:document.body.clientWidth; document.body.clientHeight;
JS代码如下:

复制代码
代码如下:

function getSize() {
var obj = new Object();
obj.allWidth = document.body.scrollWidth;
obj.allHeight = document.body.scrollHeight;
if (-[1, ]) { //非IE
obj.top = document.body.scrollTop;
obj.left = document.body.scrollLeft;
if (document.compatMode === 'CSS1Compat') {
obj.width = document.documentElement.clientWidth;
obj.height = document.documentElement.clientHeight;
}
else {
obj.width = document.body.clientWidth;
obj.height = document.body.clientHeight;
}
} else {
if (document.compatMode === 'CSS1Compat') {
obj.width = document.documentElement.clientWidth;
obj.height = document.documentElement.clientHeight;
obj.top = document.documentElement.scrollTop;
obj.left = document.documentElement.scrollLeft;
}
else {
obj.width = document.body.clientWidth;
obj.height = document.body.clientHeight;
obj.top = document.body.scrollTop;
obj.left = document.body.scrollLeft;
}
}
alert(obj.top);
alert(obj.left);
alert(obj.width);
alert(obj.height);
return obj;
}

注:发现博客园首页的HTML文档类型为:

为什么和随笔展示页不一样呢?

欢迎转载,转载请注明:转载自[ http://www.cnblogs.com/zjfree/ ]

-六神源码网