HTML文档类型
来源:互联网 发布:ue4是什么软件 编辑:程序博客网 时间:2024/04/30 05:38
昨天给添加了在线测试效果!打开后发现JS弹出框位置和效果不对!但是我在我本地测试是没问题的!仔细检查后发现原来是由于博客园的HTML文档类型和我的不一样。
我的是:<!DOCTYPE html>
博客园:<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
关于HTML文档类型参考:http://i.wanz.im/2010/05/28/why_doctype_html/
检查发现JS在获取当前页面可视大小,和页面滚动位置有差别!
在页面包含一个2000*2000的DIV是IE和Chrome在不同HTML文档类型测试整理数据如下:
标准:<!DOCTYPE html>
特殊:<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
当HTML中未添加HTML文档类型时,默认为特殊模式!
Chrome标准Chrome特殊IE标准IE特殊document.body.clientTop;0002document.body.clientLeft;0002document.body.clientWidth;473473471471document.body.clientHeight;20006252000604document.body.scrollTop;2242890255document.body.scrollLeft;3153880278document.body.scrollWidth;2005200520052010document.body.scrollHeight;2010201020002005document.body.offsetTop;0000document.body.offsetLeft;0000document.body.offsetWidth;473473471492document.body.offsetHeight;200020002000625document.documentElement.clientTop;0000document.documentElement.clientLeft;0000document.documentElement.clientWidth;4734734710document.documentElement.clientHeight;62520106040document.documentElement.scrollTop;001990document.documentElement.scrollLeft;002410document.documentElement.scrollWidth;200520052005492document.documentElement.scrollHeight;201020102010625document.documentElement.offsetTop;0000document.documentElement.offsetLeft;0000document.documentElement.offsetWidth;473473492492document.documentElement.offsetHeight;20102010625625分析:
页面总宽度: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文档类型为:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
为什么和随笔展示页不一样呢?
- HTML文档类型
- HTML文档类型
- HTML文档类型
- HTML 文档类型
- HTML文档类型
- HTML文档类型说明
- HTML文档类型
- HTML文档类型
- HTML文档类型
- <html>文档类型
- HTML 文档类型
- 统计 text/html 文档类型
- html的文档类型DTD
- HTML文档类型的重要性
- Bootstrap HTML 5 文档类型
- HTML DOCTYPE 标签 -- DTDs 文档类型声明
- html 怪异模式 文档类型定义
- HTML DOCTYPE 标签 -- DTDs 文档类型声明
- objective-c(三)
- http://maven.apache.org/ant-tasks/usage.html
- PL/SQL Developer 9 注册机下载
- CSS定义p每段落首行自动空两格
- mongodb2.2源码分析(一)
- HTML文档类型
- XPCOM指南-1_XPCOM概述
- 开发网页游戏前奏 - 各种工具
- mongodb源码分析(二)
- TankWar 小游戏源码
- VS中如何解决CUDA程序warning C4819
- 《coredump问题原理探究》windows版8.2节堆布局堆块结构
- 2012-12-24
- 关于Oracle中in和exists的区别