在HTML文本中,用尖括号括起来的部分称为,标签通常有开始标签和结束标签,它们一起限定了这个标签所包含的内容。属性只能在开始标签中指定,属性值可以用单引号或双引号括起来。结束标签都以/加上标签名来表示。有时候,有些标签并不包含其它内容(只包括自己的属性,甚至连属性都没有),这种情况下,可以写成类似这样:<img src="logo.gif" />。注意最后的一个空格和一个反斜杠,它说明这个标签已经结束,不需要单独的结束标签了。
某些标签包含的内容中还可以有新的标签,新的标签名甚至可能还可以与包含它的标签的名称相同(哪些标签可以包含标签,可以包含哪些标签也是有规定的)。在这种情况下,最后出现的标签应该起先结束。比如:
<div> <div>分类目录...</div> <div>当前分类内容列表...</div> </div>HTML文档里所有的空白符(空格,Tab,换行,回车)会被浏览器忽略,唯一的例外是空格,对空格的处理方式是所有连续的空格被当成一个空格,不管有一个,还是两个,还是100个。之所以有这样的规则是因为忽略空白符能让使用HTML的作者以他觉得最方便的格式来排列内容,比如可以在每个标签开始后增加缩进,标签结束后减少缩进。由于英语文本中空格用得很普遍(用于分隔单词),所以对空格做了这样的特殊处理。如果要显示连续的空格(比如为了缩进),应该用 来代表空格。
常用标签介绍文本
最常用的标签可能是<font>了,它用于改变字体、字号和文字颜色。
<font size="6">6</font> <font size="4">4</font> <font color="red" size="5">红色的5</font> <font face="黑体">黑体的字</font>加粗、下划线和斜体字也是常用的文字效果,它们分别用<b>,<u>,<i>表示:
<b>Bold</b> <i>italic</i> <u>underline</u>还有一些标签,用来指出包含的文本有特殊的意义,比如<abbr>(表示缩写),<em>(表示强调),<strong>(表示更强地强调),<cite>(表示引用),<address>(表示地址)等等。这些标签不是为了定义显示效果而存在的,所以从浏览器里看它们可能没有任何效果,也可能不同的浏览器对这些标签的显示效果完全不同。
一篇很长的文章,如果有合适的小标题的话,就可以快速地对它的内容进行大致的了解。在HTML里,用来表示标题的标签有:<h1>,<h2>,<h3>,<h4>,<h5>,<h6>,它们分别表示一级标题,二级标题,三级标题...
<h1>HTML基础教程</h1> <h2>什么是HTML</h2> ... <h2>HTML是什么样的</h2> ...<hr>标签用于在页面上添加横线。可以通过指定width和color属性来控制横线的长度和颜色。
<hr width="90%" color="red" /><img>标签用于在页面上添加图片,src属性指定图片的地址,如果无法打开src指定的图片,浏览器通常会在页面上需要显示图片的地方显示alt属性定义的文本。
<img src="http://www.w3.org/Icons/valid-xhtml10" alt="图片简介" />链接
超级链接用<a>标签表示,href属性指定了链接到的地址。<a>标签可以包含文本,也可以包含图片。
<a href="http://www.rkxy.com.cn">乐呵呵网</a><a href="http://validator.w3.org"><img src="http://www.w3.org/Icons/valid-xhtml10" alt="验证HTML" /></a>分段与换行
由于HTML文档会忽略空白符,所以要想保证正常的分段换行的话,必须指出哪些文字是属于同一段落的,这就用到了标签<p>。
<p>这是第一段。</p> <p>这是第二段。</p>也可以用<br>。<br>只表示换行,不表示段落的开始或结束,所以通常没有结束标签。
这是第一段。<br /> 这是第二段。<br />有时,要把文档看作不同的部分组合起来的,比如一个典型的页面可能包括三个部分:页头,主体,页脚。<div>标签专门用于标明不同的部分:
<div>页头内容</div> <div>主体内容</div> <div>页脚内容</div>注:DIV标签与CSS代码(DIV+CSS)是目前最符合规范的网页排版方法,做到了内容与样式的分离。
表格HTML文档在浏览器里通常是从左到右,从上到下地显示的,到了窗口右边就自动换行。为了实现分栏的效果,很多入使用表格(<table>)进行页面排版(虽然HTML里提供表格的本意不是为了排版)。
<table>标签里通常会包含几个<tr>标签,<tr>代表表格里的一行。<tr>标签又会包含<td>标签,每个<td>代表一个单元格。
<table> <tr> <td>2000</td><td>悉尼</td> </tr> <tr> <td>2004</td><td>雅典</td> </tr> <tr> <td>2008</td><td>北京</td> </tr> </table><tr>标签还可以被<table>里的<thead>或<tbody>或<tfoot>包含。它们分别代表表头,表正文,表脚。在打印网页的时候,如果表格很大,一页打印不完,<thead>和<tfoot>将在每一页出现。
<th>和<td>非常相似,也用在<tr>里边,不同的是<th>代表这个单元格是它所在的行或列的标题。
<table> <thead> <tr><th>时间</th><th>地点</th></tr> </thead> <tbody> <tr><td>2000</td><td>悉尼</td></tr> <tr><td>2004</td><td>雅典</td></tr> <tr><td>2000</td><td>北京</td></tr> </tbody> </table>列表
表格用于表示二维数据(行,列),一维数据则用列表表示。列表可以分为无序列表(<ul>),有序列表(<ol>)和定义列表(<dl>)。前两种列表更常见一些,都用<li>标签包含列表项目。
无序列表表示一系列类似的项目,它们之间没有先后顺序。
<ul> <li>苹果</li> <li>桔子</li> <li>桃</li> </ul>有序列表中各个项目间的顺序是很重要的,浏览器通常会自动给它们产生编号。
<ol> <li>打开冰箱门</li> <li>把大象赶进去</li> <li>关上冰箱门</li> </ol>框架
最后谈一下框架,曾经非常流行的技术,框架使一个窗口里能同时显示多个文档。搜索引擎目前无法识别框架中的内容,对SEO十分不利,一般很少使用。
主框架页里面没有<body>标签,取代它的是<frameset>。
<frameset>标签的属性Rows和Cols用于指定框架集(frameset)里有多少行(列),以及每行(列)的高度(宽度)。
<frameset>标签可以包含<frame>标签,每个<frame>标签代表一个文档(src属性指定文档的地址)。
如果觉得这样的页面还不够复杂的话,还可以在<frameset>标签里包含<frameset>标签。
<frameset rows="15%,*"> <frame src="top.html" name=title scrolling=no> <frameset cols="20%,*"> <frame src="left.html" name=sidebar> <frame src="right.html" name=recipes> </frameset> </frameset>