zoukankan      html  css  js  c++  java
  • 聊一聊HTML <!DOCTYPE> 标签

    一般一个基本html页面的结构,如下代码所示:

    <html>
    
        <head>
    
            <title>我是基本的页面结构</title>
    
        </head>
    
        <body>
    
            //...一些其他代码
    
        </body>
    </html>
    

    基本的页面有了,那这个页面里的字符,浏览器要怎么来解析呢。浏览器只能根据自己的理解来生成DOM tree。然后按照自己的方式,根据里面的标签来生成对应的对象及对象层级关系。如果想把页面真正的渲染出来就需要告诉浏览器按照怎样一种规则来渲染,如果没有浏览器就会想当然的去做了。

    HTML的定义使用DTD文件,这种格式用来定义SGML族语言,它包含对所有允许的元素的定义,包括它们的属性和层级关系。

    当没有引入doctype标签时,页面是按照怪异模式(quirks mode)渲染的,这时候页面对样式的解析是使用浏览器的方式进行的,因为各个浏览器厂商对于页面各元素的解析行为各不相同,导致大家各有各的样,奇奇怪怪的(我是这样理解的)。
    当引入doctype标签后,页面就是按照doctype标签的声明的标准,对各元素进行解析来渲染。这个时候由于声明的标准都是一致的,浏览器在对各元素的渲染方式也就相同了,这个时候页面可以在多数浏览器中实现相同的排版。这样的大家都统一了,都是按照一个标准在走,所以这个时候页面就处于标准模式(strict mode)。

    怎样切换这两种模式呢?

    第1种方法,通过添加和删除doctype来让页面处于相应的模式。
    第2种方法,在IE中可以通过切换文档模式来快速切换。

    具体这个切换有什么用,其实没什么用。
    有时IE出现样式错乱,可以通过观察这个文档模式来确定BUG产生原因。
    比如,之前的文章中写到过的,在文档声明前出现注释这种情况的BUG。

    而在现代浏览器中,怪异模式也能很好的解析。

    了解过去才知未来

    在HTML 4.01中,DOCTYPEK声明引用DTD,基于SGML的语言标准。DTD的标记语言的规则,使浏览器可以正确呈现。
    HTML5时代的到来,已经不基于SGML,所以也不需要引用DTD了。
    下面就简单的介绍一下HTML4.01中的几种经常引用的DOCTYPE声明。

    HTML 4.01 Strict

    该DTD包含所有HTML元素和属性,但不包括展示性的和弃用的元素(比如font)。不允许框架集(Framesets)

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">

    HTML 4.01 Transitional

    该DTD包含所有HTML元素和属性,包括展示性的和弃用的元素(比如font)。不允许框架集(Framesets)

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

    HTML 4.01 Frameset

    该DTD等于与HTML 4.01 Transitional。但允许框架集(Framesets)

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd">

    XHTML 1.0 Strict

    该 DTD 包含所有 HTML 元素和属性,但不包括展示性的和弃用的元素(比如 font)。不允许框架集(Framesets)。必须以格式正确的 XML 来编写标记。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

    XHTML 1.0 Transitional

    该 DTD 包含所有 HTML 元素和属性,包括展示性的和弃用的元素(比如 font)。不允许框架集(Framesets)。必须以格式正确的 XML 来编写标记。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

    XHTML 1.0 Frameset

    该 DTD 包含所有 HTML 元素和属性,包括展示性的和弃用的元素(比如 font)。但允许框架集(Framesets)。必须以格式正确的 XML 来编写标记。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">

    XHTML 1.1

    该 DTD 等同于 XHTML 1.0 Strict,但允许添加模型(例如提供对东亚语系的 ruby 支持)。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

    HTML5的声明

    <!DOCTYPE html>

    是不是眼睛看花了,我也看花了,写了这么多年的页面。前半时间都是在和html 4.01及xhtml打交道,但也没怎么去记这个。听说以前有的公司还会专门让默写这个,阿门。

    DW中的文档类型设置

    很多人的入门都是从DW开始。使用DW,可以在菜单里找到编辑-首选参数-创建文档-默认文档类型进行设置。对应图片大致如下:

    选择相应的文档类型,下次再创建时会自动生成对应的文档类型的头。

    如果你想装B,非要记住上面的这些个字符头。我会说你闲得蛋疼,下面可以这样去记(好吧我也蛋疼了),xhtml类似。
    第1步记住基本代码

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 填空1//EN" "http://www.w3.org/TR/html4/填空2.dtd">

    第2步记住文档类型英文

    html 4.01类型
    Strict (空 Strict)
    Transitional (Transitionnal loose)
    Frameset(Frameset frameset)
    

    第3步填进去

    如果你在默默记,一个你可以去吹牛了,另一个你应该尽快尝试HTML5了。

    小提示

    • 声明没有结束标签
    • 声明对大小写不敏感
    • 始终向 HTML 文档添加 <!DOCTYPE> 声明,这样浏览器才能获知文档类型。
    • 声明必须是 HTML 文档的第一行
    • 声明不是 HTML 标签;它是指示 web 浏览器关于页面使用哪个 HTML 版本进行编写的指令。

    总结

    个人拙见:在整个HTML的演进过程中,文档类型各浏览器解析页面依据的标准,促进了html语言的发展,也方便广大页面开发人员,可以把主要精力放到创新页面内容上,而不是各种兼容上。HTML5的出现,也是这种统一后的发展。大家不在寻求各自的特立独行,而是创造更好的生态环境,把对标准的实现做为目标。之后这些进入历史的内容,也就留给我们吹吹牛得了。那里讲得不对的,真心希望可以指出来,以纠正我长久的认知错误。

    附录一:SGML

    以下内容来自百度百科

    简介

    标记分为两种:
    一种称为procedardmarkup,用来描述文档显示的样式;
    另一种称为descriptive markup,用来描述文档中的文字的用途。制定SGML的基本思想是把文档的内容与样式分开。

    工作原理

    一个典型的文档可被分成3个层次:结构(structure)、内容(content)和样式(style)。SGML主要是处理结构和内容之间的关系。

    (1) 结构

      为了描述文档的结构,SGML定义了一个称为“文档类型定义(Document Type Definition,DTD)”的文件(file),它为组织文档的文档元素(例如章和章标题,节和主题等)提供了一个框架。此外,DTD还为文档元素之间的相互关系制定了规则。例如,“章的标题必须是在章开始之后的第一个文档元素”,“每个列表至少要有两个项目”等。DTD定义的这些规则可以确保文档的一致性。

    (2) 内容

      这里指的内容就是信息本身。内容包括信息名称(标题)、段落、项目列表和表格中的具体内容,具体的图形和声音等。确定内容在DTD结构中的位置的方法称为“加标签(tagging)”,而创建SGML文档实际上就是围绕内容插入相应的标签。这些标签就是给结构中的每一部分的开始和结束做标记。

    附录二:HTML 元素和有效的 DTD

    标签HTML5HTML 4.01 / XHTML 1.0XHTML 1.1
    TransitionalStrictFrameset
    <a> Yes Yes Yes Yes Yes
    <abbr> Yes Yes Yes Yes Yes
    <acronym> No Yes Yes Yes Yes
    <address> Yes Yes Yes Yes Yes
    <applet> No Yes No Yes No
    <area> Yes Yes Yes Yes No
    <article> Yes No No No No
    <aside> Yes No No No No
    <audio> Yes No No No No
    <b> Yes Yes Yes Yes Yes
    <base> Yes Yes Yes Yes Yes
    <basefont> No Yes No Yes No
    <bdi> Yes No No No No
    <bdo> Yes Yes Yes Yes No
    <big> No Yes Yes Yes Yes
    <blockquote> Yes Yes Yes Yes Yes
    <body> Yes Yes Yes Yes Yes
    <br> Yes Yes Yes Yes Yes
    <button> Yes Yes Yes Yes Yes
    <canvas> Yes No No No No
    <caption> Yes Yes Yes Yes Yes
    <center> No Yes No Yes No
    <cite> Yes Yes Yes Yes Yes
    <code> Yes Yes Yes Yes Yes
    <col> Yes Yes Yes Yes No
    <colgroup> Yes Yes Yes Yes No
    <command> Yes No No No No
    <datalist> Yes No No No No
    <dd> Yes Yes Yes Yes Yes
    <del> Yes Yes Yes Yes No
    <details> Yes No No No No
    <dfn> Yes Yes Yes Yes Yes
    <dir> No Yes No Yes No
    <div> Yes Yes Yes Yes Yes
    <dl> Yes Yes Yes Yes Yes
    <dt> Yes Yes Yes Yes Yes
    <em> Yes Yes Yes Yes Yes
    <embed> Yes No No No No
    <fieldset> Yes Yes Yes Yes Yes
    <figcaption> Yes No No No No
    <figure> Yes No No No No
    <font> No Yes No Yes No
    <footer> Yes No No No No
    <form> Yes Yes Yes Yes Yes
    <frame> No No No Yes No
    <frameset> No No No Yes No
    <head> Yes Yes Yes Yes Yes
    <header> Yes No No No No
    <h1> to <h6> Yes Yes Yes Yes Yes
    <hr> Yes Yes Yes Yes Yes
    <html> Yes Yes Yes Yes Yes
    <i> Yes Yes Yes Yes Yes
    <iframe> Yes Yes No Yes No
    <img> Yes Yes Yes Yes Yes
    <input> Yes Yes Yes Yes Yes
    <ins> Yes Yes Yes Yes No
    <keygen> Yes No No No No
    <kbd> Yes Yes Yes Yes Yes
    <label> Yes Yes Yes Yes Yes
    <legend> Yes Yes Yes Yes Yes
    <li> Yes Yes Yes Yes Yes
    <link> Yes Yes Yes Yes Yes
    <map> Yes Yes Yes Yes No
    <mark> Yes No No No No
    <menu> Yes Yes No Yes No
    <meta> Yes Yes Yes Yes Yes
    <meter> Yes No No No No
    <nav> Yes No No No No
    <noframes> No Yes No Yes No
    <noscript> Yes Yes Yes Yes Yes
    <object> Yes Yes Yes Yes Yes
    <ol> Yes Yes Yes Yes Yes
    <optgroup> Yes Yes Yes Yes Yes
    <option> Yes Yes Yes Yes Yes
    <output> Yes No No No No
    <p> Yes Yes Yes Yes Yes
    <param> Yes Yes Yes Yes Yes
    <pre> Yes Yes Yes Yes Yes
    <progress> Yes No No No No
    <q> Yes Yes Yes Yes Yes
    <rp> Yes No No No No
    <rt> Yes No No No No
    <ruby> Yes No No No No
    <s> Yes Yes No Yes No
    <samp> Yes Yes Yes Yes Yes
    <script> Yes Yes Yes Yes Yes
    <section> Yes No No No No
    <select> Yes Yes Yes Yes Yes
    <small> Yes Yes Yes Yes Yes
    <source> Yes No No No No
    <span> Yes Yes Yes Yes Yes
    <strike> No Yes No Yes No
    <strong> Yes Yes Yes Yes Yes
    <style> Yes Yes Yes Yes Yes
    <sub> Yes Yes Yes Yes Yes
    <summary> Yes No No No No
    <sup> Yes Yes Yes Yes Yes
    <table> Yes Yes Yes Yes Yes
    <tbody> Yes Yes Yes Yes No
    <td> Yes Yes Yes Yes Yes
    <textarea> Yes Yes Yes Yes Yes
    <tfoot> Yes Yes Yes Yes No
    <th> Yes Yes Yes Yes Yes
    <thead> Yes Yes Yes Yes No
    <time> Yes No No No No
    <title> Yes Yes Yes Yes Yes
    <tr> Yes Yes Yes Yes Yes
    <track> Yes No No No No
    <tt> No Yes Yes Yes Yes
    <u> No Yes No Yes No
    <ul> Yes Yes Yes Yes Yes
    <var> Yes Yes Yes Yes Yes
    <video> Yes No No No No
    <wbr> Yes No No No No

     扩展阅读:

    浏览器是怎样工作的(一):基础知识

    浏览器是怎样工作的:渲染引擎,HTML解析

    HTML解析原理

    前端科普文:为什么<!DOCTYPE>不可或缺

  • 相关阅读:
    SQL删除重复记录
    C#分页插件 Webdiyer
    B/S系统操作日志设计思路
    VS2010自动添加版权信息以及更改默认的jquery库
    Gridview中添加CheckBox全选
    利用log4net记录操作日志
    如何在定义游标的时候使用动态sql语句
    java 获取指定月份第一天和最后一天
    java 判断星期几
    SSH登陆错误"WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! "
  • 原文地址:https://www.cnblogs.com/wengxuesong/p/5560484.html
Copyright © 2011-2022 走看看