HTML是提供网页文档内容的上下文结构和含义;HTML本身是没有表现的,我们看到的例如<H3>是粗体,字号为2em;<strong>的加粗,不要认为这些是html的表现,这是html的默认样式在起作用,所以我们要知道html和页面的表现是没有关系的,表现是CSS的事。
html在页面中的作用是结构、含义,说白了就是划分内容,这里放什么,我们放的是什么。
一个页面比作房子,那HTML就是钢筋混凝土的墙,房盖房梁一样的架子;而CSS就是装饰材料,地板油漆一类的东西。
好的页面结构就是在没有CSS装饰的情况下,页面结构依然清晰明了,房屋依然可现。
而人们常说的DIV+CSS,只是通俗的说法,并不是通篇的DIV,记住:DIV不是神!
语义化HTML是一种对文本内容和意义(即语义)的补充说法。
它会告诉我们说:“这行是一个标题,这几行组成一个段落,这是一个项目列表,那是一个链接。
”而不是来告诉我们:“这些字是蓝色的,那些又是红色的,这部分内容靠右,这几个是斜体。
”这些是CSS的工作。
总之:HTML告诉我们一块内容是什么(或其意义),而不是它长什么样子。
复制代码代码如下:
<!--未语义化-->
<div id="header">
<div class="H3">前砖攻城师</div>
<div class="h2">搭积木也要玩艺术</div>
</div>
<!--语义化之后-->
<div id="header">
<H3>前砖攻城师</H3>
<h2>搭积木也要玩艺术</h2>
</div>
- 去掉样式能让页面结构呈现清晰
- 屏幕阅读器会按标记“读”你的网页
- 有益于SEO
- 便于团队开发和维护
附:HTML5新增元素
比如来自一个外部的新闻提供者的一篇新的文章,或者来自 blog 的文本,或者是来自论坛的文本。
亦或是来自其他外部源内容
HTML5:<article></article>
HTML4:<div></div>
比如章节、页眉、页脚或文档中的其他部分。
HTML5: <section></section>
HTML4: <div></div>
aside 的内容应该与 article 的内容相关。
HTML5:<aside>Aside 的内容是独立的内容,但应与文档内容相关。
</aside>
HTML4:<div>Aside 的内容是独立的内容,但应与文档内容相关。
</div>
HTML5: <header></header>
HTML4: <div></div>
典型地,它会包含创作者的姓名、文档的创作日期以及/或者联系信息。
HTML5: <footer></footer>
HTML4: <div></div>
HTML5: <hgroup></hgroup>
HTML4: <div></div>
HTML4:<ul></ul>
这个 HTML 元素是为了客户端矢量图形而设计的。
它自己没有行为,但却把一个绘图 API 展现给客户端 JavaScript 以使脚本能够把想绘制的东西都绘制到一块画布上。
HTML5:<canvas id="myCanvas" width="200" height="200"></canvas>
HTML4:<object data="inc/hdr.svg" type="image/svg+xml" width="200" height="200"></object>
HTML5: <video src="movie.ogg" controls="controls">您的浏览器不支持 video 标签。
</video>
HTML4:<object type="video/ogg" data="movie.ogv"><param name="src" value="movie.ogv"></object>
HTML5:<audio src="someaudio.wav">您的浏览器不支持 audio 标签。
</audio>
HTML4:<object type="application/ogg" data="someaudio.wav"><param name="src" value="someaudio.wav"></object>
HTML5: <embed src="horse.wav" />
HTML4: <object data="flash.swf" type="application/x-shockwave-flash"></object>
HTML5: <source>
HTML4: <param>
与 input 元素配合使用,就可以制作出输入值的下拉列表。
HTML5: <datalist></datalist>
HTML4: none
与 <legend> 一起使用,来制作 detail 的标题。
该标题对用户是可见的,当在其上点击时可打开或关闭 detail。
HTML5: <details></details>
HTML4: <dl style="display:hidden"></dl>
”summary” 元素应该是 “details” 元素的第一个子元素。
HTML5: <details><summary>HTML 5</summary>This document teaches you everything you have to learn about HTML 5.</details>
HTML4: none
使用 <figcaption> 元素为元素组添加标题。
HTML5: <figure><figcaption>PRC</figcaption><p>The People's Republic of China was born in 1949...</p></figure>
HTML4: <dl><H3>PRC</H3><p>The People's Republic of China was born in 1949...</p></dl>
”figcaption” 元素应该被置于 “figure” 元素的第一个或最后一个子元素的位置。
HTML5: <figure><figcaption>PRC</figcaption></figure>
HTML4: none
<mark>标签的一个比较典型的应用就是在搜索结果中向用户高亮显示搜索关键词。
HTML5: <mark></mark>
HTML4: <span></span
仅用于已知最大和最小值的度量。
必须定义度量的范围,既可以在元素的文本中,也可以在 min/max 属性中定义。
HTML5: <meter></meter>
HTML4: none
HTML5: <output></output>
HTML4: <span></span>
可以使用 <progress> 标签来显示 JavaScript 中耗费时间的函数的进程。
HTML5: <progress></progress>
HTML4: none
HTML5: <time></time>
HTML4: <span></span>
HTML4: none
HTML5: <command onclick=cut()" label="cut">
HTML4: none
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)