- 浏览: 149613 次
- 性别:
- 来自: 杭州
最新评论
-
luliangy:
我是直接放在URL里面的出了错,试了下放在data里面就没问题 ...
HttpURLConnection乱码问题解决 -
luliangy:
我是在服务端(webx)getBytes iso8895-1然 ...
HttpURLConnection乱码问题解决 -
cwalet:
bazhuang 写道liwanfeng 写道
data = ...
HttpURLConnection乱码问题解决 -
cl1154781231:
connection.getOutputStream(),&q ...
HttpURLConnection乱码问题解决 -
bazhuang:
liwanfeng 写道
data = new String ...
HttpURLConnection乱码问题解决
认识DOCTYPE
带着问题入手:想获取浏览器可视高度,为什么利用document.body.clientHeight有时候会失效,上网搜索之后使用document.documentElement.clientHeight能解决,但有时候也会出问题。
当我们打开一个网页的源代码,一般我们会看到第一行都是<!DOCTYPE……,这样的文字,DOCTYPE后面的文字会有所差别,这个东西到底有什么用处呢?
这篇文章就来说说这个DOCTYPE。
1、通过搜索引擎,我们可以搜索到DOCTYPE的一些介绍,但总是怕别人讲的不全或者有问题,那就请访问http://www.w3.org/QA/2002/04/valid-dtd-list.html,这是W3C组织的官方网站上的介绍,里面很详细的列出了可供定义的DOCTYPE,我们一般用到的是如下3个:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">
以下是从手册上摘抄的规则:
语法:
HTML 顶级元素 可用性 "注册//组织//类型 标签//定义 语言""URL"
可能值:
- 顶级元素:指定 DTD 中声明的顶级元素类型。这与声明的 SGML 文档类型相对应。 HTML 默认。HTML。
- 可用性:指定正式公开标识符(FPI)是可公开访问的对象还是系统资源。 PUBLIC 默认。可公开访问的对象。SYSTEM 系统资源,如本地文件或 URL。
- 注册:指定组织是否由国际标准化组织(ISO)注册。 + 默认。组织名称已注册。
- 组织名称未注册。Internet 工程任务组(IETF)和万维网协会(W3C)并非注册的 ISO 组织。
组织:指定表明负责由 !DOCTYPE 声明引用的 DTD 的创建和维护的团体或组织的名称,即 OwnderID。 IETF IETF。 W3C W3C。
- 类型:指定公开文本类,即所引用的对象类型。 DTD 默认。DTD。
- 标签:指定公开文本描述,即对所引用的公开文本的唯一描述性名称。后面可附带版本号。 HTML 默认。HTML。
- 定义:指定文档类型定义。
Frameset 框架集文档。
Strict 排除所有 W3C 专家希望逐步淘汰的代表性属性和元素,因为样式表已经很完善了。
Transitional 包含除 frameSet 元素的全部内容。
- 语言:指定公开文本语言,即用于创建所引用对象的自然语言编码系统。该语言定义已编写为 ISO 639 语言代码(大写两个字母)。 EN 默认。英语。
- URL:指定所引用对象的位置
为了获得正确的DOCTYPE声明,关键就是让dtd与文档所遵循的标准对应。例如,假定文档遵循的是xhtml 1.0 strict标准,文档的doctype声明就应该引用相应的dtd。另一方面,如果doctype声明指定的是xhtml dtd,但文档包含的是旧式风格的html标记,就是不恰当的;类似地,如果doctype声明指定的是html dtd,但文档包含的是xhtml 1.0 strict标记,同样是不恰当的。
2、DOCTYPE的用法,DOCTYPE描述都是放在页面的开始位置。
让我们来看一个例子:
html代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>test DOCTYPE</title>
</head>
<style>
#test{
border:1px dashed windowtext;
height:20px;
width:30px;
padding:10px;
margin:auto;
}
</style>
<body>
<div id="test">
</div>
</body>
</html>
这段代码在ie、firefox和chrome中打开的效果是,div居中。
但我们把DOCTYPE这段描述删除,看看效果如何。在firefox和chrome中效果没有变化,而在ie中就会发现div就在左边了,而并没有居中。当我们把margin:auto放到搜索引擎中进行搜索的时候,会有一堆人回答你用这个可以让div居中,但他们不会告诉你要使这个有效果的前提是有DOCTYPE。
但在ie中也会有情况是没有DOCTYPE才会起作用,我们看代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>test DOCTYPE</title>
</head>
<style>
#test{
cursor:col-resize;
height:200px;
width:300px;
position:absolute;
}
</style>
<body>
<div id="test">
</div>
</body>
</html>
本来的目的是想把test这个div上的鼠标手势修改为col-resize,但在ie中却发现不起作用,但我们把DOCTYPE描述删除掉之后就会发现生效了,而在Firefox中始终都有效。
修改方法如下:
(1)删除DOCTYPE描述;
(2)当然这里我们也可以保留DOCTYPE,在样式中增加background-color:#FFFFFF;就可以看到效果,而默认的background-color是transparent;
(3)position删除。
第2种解决方法在某些环境下不可行,div下面有一个背景图,那这个div设置了背景色就会影响效果;第3种方法基本上不考虑,设置这个position大部分时候都是程序所需。
这个大家可以在访问https://tools.alibaba-inc.com这些平台的首页的时候,那个分隔条拖动就是这个情况,我的解决方法是删除DOCTYPE。
3、transitinal.dtd、strict.dtd、frameset.dtd的区别
只是在写html标签的时候区别不是很大,我也就介绍一下对js代码的影响,由于现在的浏览器对html代码的容错能力很强,即使有语法错误也不会给与提示。
(1)frameset.dtd,如果我们的页面需要使用到frameset的话,需要使用这个dtd,否则都不允许使用;
(2)strict.dtd,严格的控制,使用这种模式之后,所有表现层的标签都不允许使用了,例如:br,b,i这些都属于表现层的标签。但目前的浏览器容错能力很强,不会强制报错,还是会正常的显示;
(3)transitional.dtd,过渡期控制,在strict的基础上兼容老的标签。
现在的浏览器解析html的时候,strict.dtd和transitional.dtd基本上没什么差别,如果严格按照W3C的约定去做的话,估计大部分网页在这种浏览器下都会变形,市场机会完全失去。
但我们去研究js的时候,会发现有没有定义DOCTYPE在某些js中产生的结果会不一样,请看例子:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>获取可视高度</title>
<style>
.info{
background-color:#ad6a9e;
padding:10px;
color:#444444;
}
</style>
<script>
function getHeight(){
var ht = document.body.clientHeight;
alert(ht);
}
</script>
</head>
<body>
<div class="info">
中新网12月24日电 据国家气象局网站消息,受强冷空气影响,未来三天,中国大部地区自西向东将迎来一次寒潮天气过程,西北地区东部偏北地区、西北地区北部和中东部、内蒙古大部、华北、东北、黄淮、江淮等地将先后出现5~7级,阵风8级偏北风;冷空气前锋过后,上述大部地区的气温将下降8~12℃,其中内蒙古中部和东南部、陕西北部、山西北部、河北北部、辽宁西部、吉林西部的气温将下降14~16℃,部分地区降温幅度可达16~18℃。内蒙古东北部、东北地区等地的部分地区有大雪或暴雪。受另一股冷空气影响,25日,新疆北部将有5~6级、山口地区8~9级大风,气温在24日回升的基础上,将下降4~8℃。
<input type="button" value="获取可视高度" onclick="getHeight();"/>
</div>
</body>
</html>
ie6、firefox、chrome浏览器的最终结果如下:
浏览器 |
IE6 |
firefox 3.0.16 |
chrome |
结果 |
96 |
97 |
100 |
显然这个不是我们想要的可视高度,倒像是这个网页中的内容高度。
那我们把DOCTYPE删除之后,再看看结果如何:
浏览器 |
IE6 |
firefox 3.0.16 |
chrome |
结果 |
726 |
709 |
805 |
这3个值就是我们最终想要的浏览器的可视高度了。
但删除DOCTYPE不就违背了w3c的原则了么,那有没有办法不删除DOCTYPE,也同样可以获得正确的结果,我们来看下面这段代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>获取可视高度</title>
<style>
.info{
background-color:#ad6a9e;
padding:10px;
color:#444444;
}
</style>
<script>
function getHeight(){
var ht = document.documentElement.clientHeight;
alert(ht);
}
</script>
</head>
<body>
<div class="info">
中新网12月24日电 据国家气象局网站消息,受强冷空气影响,未来三天,中国大部地区自西向东将迎来一次寒潮天气过程,西北地区东部偏北地区、西北地区北部和中东部、内蒙古大部、华北、东北、黄淮、江淮等地将先后出现5~7级,阵风8级偏北风;冷空气前锋过后,上述大部地区的气温将下降8~12℃,其中内蒙古中部和东南部、陕西北部、山西北部、河北北部、辽宁西部、吉林西部的气温将下降14~16℃,部分地区降温幅度可达16~18℃。内蒙古东北部、东北地区等地的部分地区有大雪或暴雪。受另一股冷空气影响,25日,新疆北部将有5~6级、山口地区8~9级大风,气温在24日回升的基础上,将下降4~8℃。
<input type="button" value="获取可视高度" onclick="getHeight()"/>
</div>
</body>
</html>
浏览器 |
IE6 |
firefox 3.0.16 |
chrome |
结果 |
726 |
709 |
805 |
和上面的结果一致,测试通过。
那我们应该找到一种方法可以解决没有DOCTYPE以及有DOCTYPE都可以正确返回结果的,兼容性做到最好。
请看如下代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>compatMode</title>
</head>
<body>
<script>
document.write(document.compatMode);
</script>
</body>
</html>
既然找到原因,那么我们就把上面的获取clientHeight代码修改一下:
function getHeight(){
var flag = document.compatMode == "CSS1Compat";
if(flag){
var ht = document.documentElement.clientHeight;
}
else{
var ht = document.body.clientHeight;
}
alert(ht);
}
通过以上的介绍,我们知道了JS不仅有不同浏览器的兼容性问题需要考虑,不同的页面定义也会造成返回结果的变化,所以有以下几点值得注意:
(1) 我们在编写页面的时候,都带上DOCTYPE这个声明,不要轻易的将其删除,除了使用frameset的地方,其他网页都使用transitional.dtd这种类型;
(2) 在编写js的时候,在获取页面的clientHeight,clientWidth,scrollHeight,scrollWidth,scrollLeft,scrollTop这些属性的时候,都需要增加对document.compatMode的判断,这样才可以保证我们的js有更强的兼容性。
发表评论
-
form的属性说明
2013-05-16 16:41 1584form在页面操作的时候是一个比较重要的标签了,那么这里就介 ... -
chrome开发要注意了
2012-06-13 12:49 0event.layerX and event.layerY a ... -
json格式查看器
2011-09-21 14:57 2160http://www.jiangliang.net/json/ ... -
需要认真学习html5
2011-08-25 23:00 1207http://www.mhtml5.com/resources ... -
遍历HtmlElement的自定义属性
2011-04-07 13:26 3471目前需要做一个需求,那就是需要用户提供一些自定义属性,可以定义 ... -
Q4计划完成的事情
2010-10-20 16:07 1195Q4在Javascript方面需要完成的事情列一下: 1、颜色 ... -
前端优化总结
2010-10-19 17:14 1466分析个性化推荐的耗时,可以分为如下几个阶段: (1) load ... -
Javascript培训PPT
2010-08-17 20:02 2450最近给其他同学做了一次Javascript培训,加上前面几次一 ... -
AJAX的缺陷以及解决方案
2010-07-02 13:44 1399目前我们正在考虑一个 ... -
DOM Level 1学习之一_关于Node
2010-06-08 15:26 1284今天想看看nodeType到底有几种情况,搜索到http:// ... -
eval部分替代方法
2010-05-23 23:04 1784function jsonDecode(data){ re ... -
IE6不缓存背景图的解决方案
2010-04-27 20:04 1952IE6有个bug,就是不缓存css中的背景图,每次都要去下载背 ... -
查询浏览器占有率
2010-04-19 16:22 1397我们可以在http://gs.statcounter.com/ ... -
事件的前因后果(2)
2010-01-22 22:40 13212、 认清事件的本质 要想解决这个问题,我们就需要认识一下事件 ... -
事件的前因后果(1)
2010-01-20 22:59 1086带着问题入手:我们做j2ee网站讲究分层,后台有好多方案进行分 ... -
探讨链接a
2009-12-14 19:23 3081谈谈对A的认识 在web开发中,打交道比较多的除了按钮就是a了 ... -
如何获取页面元素的某一个样式
2009-08-13 17:26 1631<!DOCTYPE html PUBLIC " ... -
0等于空字符串的问题
2008-06-06 22:42 2945今天碰到了一个非常郁闷的问题,本来是想实现一个类似于java里 ... -
js中创建Object对象的性能分析
2008-05-06 17:20 2149在javascript中创建一个对象有以下几种方式,如下: 1 ... -
屏蔽dom的上级节点的事件
2008-02-18 16:39 3922由于网页中的节点会继承上级节点的事件,可有时候这个事件继承并不 ...
相关推荐
DOCTYPE和XHTML的相关认识是网页制作中的核心概念,关乎到Web标准的实施和网页的兼容性。DOCTYPE(Document Type Declaration)声明是HTML或XHTML文档的开头部分,它告诉浏览器文档遵循的规范。DOCTYPE的存在确保了...
DOCTYPE html>`**:文档类型声明,告诉浏览器这是一个HTML5文档。 - **`<html>`**:文档的根元素。 - **`<head>`**:包含关于文档的元数据,如标题。 - **`<title>`**:设置浏览器标题栏或标签页的标题。 - **`...
DOCTYPE html>`,无需版本号,适用于所有HTML版本。 - **语言标签**:`<html lang="en">`代替`xmlns`或`xml:lang`。 - **编码类型**:使用`<meta charset="utf-8">`指定字符集。 - **闭合标签**:空标签如` `、`...
DOCTYPE html>声明,元素作为文档的根元素,元素包含元数据(如标题),以及元素包含实际的网页内容。 3. 使用HTML标签定义网页的各个部分,如标题(至)、段落()、链接()、图像()等。 4. 添加内容,如文本、...
【初识HTML5,认识HTML】 HTML5是超文本标记语言(HyperText Markup Language)的第五个版本,是用于创建网页的标准标记语言。自2014年正式发布以来,HTML5已经成为现代网页开发的核心,它极大地提升了用户体验,...
### 认识CSS3和HTML5 随着网络技术的发展,网页设计的需求日益复杂化与多样化。为了满足这些需求,HTML5 和 CSS3 应运而生。本文将着重介绍CSS3中的两个关键特性:`background-clip`和`background-origin`。 #### ...
9. **XML声明**:每个WML文档都应包含XML声明,以指明文档类型,例如`<?xml version="1.0"?>`,以及DOCTYPE声明,以指定文档遵循的WML版本。 在学习WML的过程中,建议先从基本语法和元素开始,然后逐步了解更复杂的...
7. WEB 标准和 W3C 的理解与认识?(WEB 标准:确保网页在不同浏览器中的统一显示,W3C:万维网联盟,制定 WEB 标准) 8. HTML 中的行内元素、块级元素和空元素分别有哪些?(行内元素:a、span 等,块级元素:div、...
【Java程序设计任务驱动式教程-任务十五-认识Java Applet (Applet入门)】 Java Applet是Java技术的一部分,它允许开发人员创建可以在Web浏览器中运行的小型应用程序,为网页提供动态交互功能。在Java早期,Applet是...
DOCTYPE HTML PUBLIC -//W3C//DTD HTML 4.01 Transitional//ENhttp://www.w3.org/TR/html4/loose.dtd> <!DOCTYPE ...
通过理解XHTML文档的开头部分,我们不仅可以了解到XHTML的基本结构和语法,还能认识到XHTML相对于传统HTML的优势,包括更严格的语法、增强的机器可读性以及更好的国际化支持。这对于开发高质量、跨平台兼容的网页至...
HTML5是现代网页开发的核心标准,它在2014年被正式确立...总之,"HTML5概述"这一章将帮助初学者建立对HTML5的基本认识,并引导他们深入学习这个强大的网页制作语言,从而更好地构建符合现代需求的、富有表现力的网页。
在学习PHP的过程中,我们首先会接触到的是对PHP的全面认识。这包括了解PHP的历史、发展背景、应用领域以及它在Web开发中的地位。PHP主要用于服务器端编程,能够处理表单数据、生成动态网页内容、与数据库交互等任务...
今天来认识一下两个我不太常用到的html标签:sub标记和sup标记。...DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.0 Transitional//EN http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd><html xmlns=h
1. **认识浏览器渲染差异** - **DOCTYPE声明**:DOCTYPE声明会影响浏览器进入何种标准模式。在IE中,没有DOCTYPE会导致怪异模式,这将导致CSS盒模型和其他行为的差异。 - **盒模型差异**:IE采用的是包含边距和...
不在清单上的元素都将被视为未知元素。浏览器不会给未知元素设定任何样式(不同浏览器对元素会有不同的默认样式)。在IE9之前的版本中,也不能对未知元素设定样式。未知元素的DOM也显示不正确,IE会在DOM中...DOCTYPE