当前位置:资讯中心主页 >HTML/DHTML >文章内容
- HTML 初学者指南
- 来源:作者: 发布时间:2007-12-19 18:03:55
-
本文是创建HTML文件的初级读物。HTML 是 WWW(World Wide Web )中使用的超文本标记语言。本指南的目的是介绍怎么使用HTML和创建 web 文件。本文中的链接指向一些附加的信息。你还能到你本地的书店查看一下,那里可能会有非常多有价值的关于 Web 和 HTML 的资料。
- 域名惊喜价格 cn域名1元注册
- com域名39.9元
域名注册
- 主机按月支付,低至19元/月
- 超大流量,可开子站点
虚拟主机
- 特惠VPS168元/月,4-8M独享带宽保证
- 独立操作系统,无限开站点
VPS主机
前言
术语
WWW
World Wide Web
Web
World Wide Web
SGML
Standard Generalized Markup Language--标准通用标记语言,描述标记语言的一个标准
DTD
Document Type Definition--文本类型定义, 这是个用SGML写成的标记语言的正式说明
HTML
HyperText Markup Language-- 超文本标记语言, 他是个SGML DTD
HTML 是一套独立于平台的格式定义( 用标记说明 ) , 用来描述World Wide Web 文件中的各个组成部分. HTML 是Tim Berners-Lee 在 CERN (在日内瓦的欧洲粒子物理实验室) 发明的.
本文不包括的内容
本指南假设读者具有以下基础:知道怎么使用 NCSA Mosaic 或其他的 Web browser
对Web 服务器和客户 browsers 有一般的理解
能访问 Web 服务器 (或你只是想用本地方式创建个人使用的HTML 文件)
HTML 版本
本指南参考最新的说明--HTML 2.0-- 加上一些已在 browsers 中广泛实现的附加特性. 及正在发展的一些新特性.HTML 文件
什么是 HTML 文件
HTML 文件是普通文本 ( ASCII) 文件, 他能用任意编缉器(如UNIX 中的Emacs 或 vi, Macintosh 中的BBEdit, 视窗系统中的Notepad)生成. 你也能使用字处理软件, 不过要记住存文件时要存成“带回车的纯文本”。HTML 编辑器
目前有一些 WYSIWYG 编辑器 (如., 可用在多种平台的 HotMetal, 或可用在 Macintosh 机的 Adobe PageMill ). 在你学了一些 HTML 标记的基本知识之后,你可能希望使用他们. 你会发现掌控足够的 HTML 编码知识对于判断一个 WYSIWYG 编辑器是否适用是非常有益处的如果你还没有选定使用哪种软件, 能参考本站软件下载 HTML 编辑器的在线例表 (按应用平台分类) ,帮助你寻找应用软件.
把文件存放到服务器上
如果你在学校或单位能访问 Web 服务器, 和你的 WEB 管理员webmaster (维护服务器的人) 联系,看看怎么把你的文件存放到 Web 上. 否则,如果在学校或单位不能访问, 能看看你的社区是否有 免费网络FreeNet, 一种提供免费 Internet 访问服务的基于社区的网络. 如果也没有免费网络, 你能当地的 Internet 服务提供者联系,他们能把你的文件存放到服务器上,不过要收取费用. (你能在当地的报纸上找到广告with your Chamber of Commerce for the names of companies.)标记说明
一个元素 element 是个文件结构的基本组成部分. 元素的例子有头 heads, 表格tables, 段落 paragraphs, 列表 lists 等. 你能这样理解: 你用 HTML 标记为浏览器标出文件的各个元素 . 元素中能包含普通文本,其他元素,或二者都有.在 HTML 文件中使用tags表示各种元素. HTML 标记由一个左尖括号 (<), 一个标记名, 和一个右尖括号 (>) 组成. 标记通常成对出现 (如, <H1> 和 </H1>) 以指出标记作用的范围. 结束标记和起始标记相似,只是在括号中的标记名中以斜杠 (/) 领头. HTML 标记在下文中列出.
有些元素可能含有一个属性 attribute, 他是包含在起始标记中的附加信息说明. 例如, 通过在图象文件的 HTML 代码中包含适当的属性,你能指明一幅图象的位置 (顶端, 中间, 或底部) . 具有可选属性的标记 如下.
注意: HTML 不区分大小写. <title> 等价于 <TITLE> 或 <TiTlE>. 有几个例外的情况列在下文中的转义序列中.
并非所有的 World Wide Web 浏览器都支持所有的标记. 如果一个浏览器不支持某个标记, 他通常只是忽略之.
最小的 HTML 文件
每个 HTML 文件应该包含一些标准 HTML 标记. 每个文件都包含头 head 和正文 body text 两部分. 头中含有标题 title, 正文中含有实际构成段落,列表和其他元素的文本. 浏览器需要具体的信息是因为他们都是根据 HTML 和 SGML 说明编程的.下面的源文件举例说明必须的元素:
<html>
<head>
<TITLE>A Simple HTML Example</TITLE>
</head>
<body>
<H1>HTML is Easy To Learn</H1>
<P>Welcome to the world of HTML.
This is the first paragraph. While short it is
still a paragraph!</P>
<P>And this is the second paragraph.</P>
</body>
</html>必须的元素有 <html>, <head>, <title>, 和 <body> 标记 (和他们相应的结束标记). 由于在每个文件中你都要包括这些标记, 你能创建一个含有这些标记的模板文件. ( 有些浏览器会自动正确地规格化你的 HTML 文件,哪怕你没有包含这些标记. 不过有些浏览器不会这样! 因此你要确保包含这些标记.)
[page]一个教学工具
要看到你的浏览器当前窗口所显示信息的原始文件, 能选择浏览器菜单中的 View Source (或等价操作) 选项. 文件的内容和所有的 HTML 标记将显示在一个新窗口中.这是学习使用 HTML 和掌控技巧和构造的一个非常好的方式. 当然, 你看的 HTML 不一定在技术上是正确的. 当你熟悉了 HTML 并且看了非常多这方面的参考资料,你将能够区分 "好的" 和 "不好的" HTML.
记住你能保存 HTML 编码的源文件,用做你的 Web 页的模板,或把他修改之后用做其他用途.
HTML 标记
HTML
该元素指明你的文件包含 HTML-编码 信息. 文件扩展名 .html 也指明该文件是个 HTML 文件而且 必须使用. (如果你的系统受 8.3 制文件名的限制 (如., LeeHome.htm), 能用 .htm 做扩展名.)HEAD
头元素 head 是你的 HTML-编码 文件中包含标题 title 的第一部分. 标题是作为你的浏览器窗口的一部分来显示的 (见下文).TITLE
标题 title 元素含有你的文件标题并且作为一种全局上下文识别其内容. 标题通常显示在浏览器窗口的某个位置 (通常在顶端), 而不是在文本区. 标题同时也用于热点列表 hotlist 或书签列表 bookmark list 中的显示, 因此标题的选择因当是描述性的, 独特的, 和相对简洁的. 标题在 WAIS 服务中还用于搜索服务器.例如, 你可能在一章的内容中包含一个短小的书本的标题: NCSA Mosaic 指南 (视窗系统): 安装. 这个标题说明了软件的名称, 使用平台, 和本章内容, 他比简单地把该文件称为 安装. 要好得多。一般你的标题应该不超过 64 个字符.
BODY
HTML 文件的第二部分,也是最大的部分是正文 body, 他含有你的文件的内容 (显示在你的浏览器窗口文本区的部分). 下面介绍的标记用在 HTML 文件的正文 body 内.标题字体Headings
HTML 有六级标题字体, 从 1 到 6 编号, 1 号最小. 标题字体的显示比普通文本字体大或粗. 每个文件中的第一个标题字体应该标记为 <H1>.标题字体元素的语法为:
<Hy>标题字体文本 </Hy>
其中 y 是从 1 到 6 的数字,指明标题字体的等级.在你的文件中不要跳跃使用标题字体等级. 例如, 不要用一级标题 (<H1>) 开始,然后跟随一个三级标题 (<H3>) .
段落Paragraphs
不同于多数字处理器中的文件, HTML 文件中的换行是不重要的. 你不用担心你的文本中行的长度 ( 当然最佳不要超过 72 个字符). 在你的源文件中所有地方能使用换行, 多个空白在你的浏览器中被重叠成为一个空白.在“最小的 HTML 文件”中给出的例子中第一段的编码为
<P>Welcome to the world of HTML.
This is the first paragraph.
While short it is
still a paragraph!</P>源文件中各行之间有换行. Web 浏览器忽略这些换行,只有遇见另一个 <p> 标记时才开始新段落 <P>
要点: 你必须用 <P> 元素指明段落. 浏览器忽略源文件中的所有缩进或空行. 如果没有 <P> 元素, 文件将被看作一个大段落处理. (一个例外的情况是把文本标记为 "preformatted," 下文中将做介绍.) 例如, 下面的内容的输出和第一个 HTML 例子完全相同:
<H1>Level-one heading</H1> <P>Welcome to the world of HTML. This is the
first paragraph. While short it is still a
paragraph! </P> <P>And this is the second paragraph.</P>为了保持 HTML 文件的可读性, 标题字体应该独占一行, 在开始一个新的部分之前加一到两行空行,段落之间也用空行隔开( 除了用<P> 标记以外). 这些额外的空白在你编辑文件时将会有用 ( 不过你的浏览器将忽略这些空白因为他有自己的关于空白的规则,不依赖于你源文件中的空白).
注意: 结束标记 </P> 能省略. 这是因为当浏览器遇见一个 <P> 标记时, 他认为前一个段落到此结束.
使用 <P> 和 </P> 作为段落标记使得你能通过在源文件中使用 ALIGN=alignment 属性使一个段落居中排列.
<P ALIGN=CENTER>
这是个居中的段落. [见下面的输出形式]
</P>这是个居中的段落.[page]
列表Lists
HTML 支持不编号 unnumbered, 编号numbered, 和定义definition 三种列表. 你也能嵌套列表, 不过不要嵌套过多,否则会使读者感到不清晰。不编号列表Unnumbered Lists
制作一个不编号的,公告式列表,
用开始标记 <UL> ( unnumbered list 的简记) 开始
输入 <LI> (list item) 标记,后面跟独立的项; 不需使用 </LI> 标记
用 </UL> 标记结束整个列表
下面是个有三个项的列表:<UL>
<LI> apples
<LI> bananas
<LI> grapefruit
</UL>输出形式为:
apples
bananas
grapefruit
<LI> 项能含有多个段落. 用段落标记 <P> 指明.编号列表Numbered Lists
编号列表 (也称为 有序列表ordered list) 和不编号列表相同, 只是用 <OL> 代替 <UL>. 各项同样用 <LI> 标记. 下面的 HTML 代码:
<OL>
<LI> oranges
<LI> peaches
<LI> grapes
</OL>产生的输出为:
oranges
peaches
grapes
定义列表Definition Lists定义列表 (编码为 <DL>) 通常含有交替出现的 定义术语definition term (编码为 <DT>) 和定义描述definition definition (编码为 <DD>). Web 浏览器通常另起一行显示定义描述.
下面是个定义列表的例子:
<DL>
<DT> NCSA
<DD> NCSA, the National Center for Supercomputing Applications,
is located on the campus of the University of Illinois
at Urbana-Champaign.
<DT> Cornell Theory Center
<DD> CTC is located on the campus of Cornell University in Ithaca,
New York.
</DL>输出形式为:
NCSA
NCSA, the National Center for Supercomputing Applications, is located on the campus of the University of Illinois at Urbana-Champaign.
Cornell Theory Center
CTC is located on the campus of Cornell University in Ithaca, New York.
<DT> 和 <DD> 项能包含多个段落 (用 <P> 标记指示), 列表, 或其他的定义信息.COMPACT 属性可能会被经常使用,如果你的定义术语非常简短的话. 例如,如果你想显示一些计算机选项, 他们能和定义的开始处于同一行中.
<DL COMPACT>
<DT> -i
<DD>invokes NCSA Mosaic for Microsoft 视窗系统 using the
initialization file defined in the path
<DT> -k
<DD>invokes NCSA Mosaic for Microsoft 视窗系统 in kiosk mode
</DL>输出形式为:
-i
invokes NCSA Mosaic for Microsoft 视窗系统 using the initialization file defined in the path.
-k
invokes NCSA Mosaic for Microsoft 视窗系统 in kiosk mode.
嵌套列表Nested Lists列表能嵌套. 在每个列表项中,你还能含有多个段落,每个段落含有嵌套列表.
[page]
这里是个嵌套列表的例子:
<UL>
<LI> A few New England states:
<UL>
<LI> Vermont
<LI> New Hampshire
<LI> Maine
</UL>
<LI> Two Midwestern states:
<UL>
<LI> Michigan
<LI> Indiana
</UL>
</UL>这个嵌套列表的显示:
A few New England states:
Vermont
New Hampshire
Maine
Two Midwestern states:
Michigan
Indiana
预排格式文本Preformatted Text
用<PRE> 标记 (表示 "preformatted") 能产生固定宽度的字体. 该标记同时使空格,新行,和制表键 tabs 有效 (多个空格显示为多个空格, 源文件中的换行也在浏览器中产生换行). 这对于程式清单和其他一些情况是非常有用的. 例如, 下面的行:<PRE>
#!/bin/csh
cd $SCR
cfs get mysrc.f:mycfsdir/mysrc.f
cfs get myinfile:mycfsdir/myinfile
fc -02 -o mya.out mysrc.f
mya.out
cfs save myoutfile:mycfsdir/myoutfile
rm *
</PRE>显示为:
#!/bin/csh
cd $SCR
cfs get mysrc.f:mycfsdir/mysrc.f
cfs get myinfile:mycfsdir/myinfile
fc -02 -o mya.out mysrc.f
mya.out
cfs save myoutfile:mycfsdir/myoutfile
rm *<PRE> 标记能带一个宽度属性 WIDTH ,指明一行中最多允许的字符数. WIDTH 同时通知浏览器选择一个合适的字体及文本的缩排.
在 <PRE> 作用的部分中也能加超链. 不过其他的 HTML 标记应该避免在 <PRE> 的区间中使用.
注意,由于<, >, 和 & 在 HTML 文件中有特别含义, 在你输入这些字符的时候必须使用他们的转义序列 (分别为<, >, 和 &) . 周详内容参见转义序列 .
大范围引用Extended Quotations
使用 <BLOCKQUOTE> 标记能在屏幕上用分离的块显示大段的引用. 多数浏览器通常改动引用部分的页边界,以和周围的文本区分开.在下面的例子中:
<BLOCKQUOTE>
<P>Omit needless words.</P>
<P>Vigorous writing is concise. A sentence should contain no
unnecessary words, a paragraph no unnecessary sentences, for the
same reason that a drawing should have no unnecessary lines and a
machine no unnecessary parts.</P>
--William Strunk, Jr., 1918
</BLOCKQUOTE>显示结果为:
Omit needless words.
Vigorous writing is concise. A sentence should contain no unnecessary words, a paragraph no unnecessary sentences, for the same reason that a drawing should have no unnecessary lines and a machine no unnecessary parts.
--William Strunk, Jr., 1918
[page]
地址Addresses
<ADDRESS> 标记通常用于说明文件的作者, 和作者联系的方法 (如, 一个电子邮件地址), 和一个修订日期. 他一般是个文件的最后部分.例如, 本在线指南的最后一行为:
<ADDRESS>
A Beginner’s Guide to HTML / NCSA / pubs@ncsa.uiuc.edu / revised April 96
</ADDRESS>结果为:
A Beginner’s Guide to HTML / NCSA / pubs@ncsa.uiuc.edu / revised April 96
注意: <ADDRESS> 不 用于普通邮政地址. 关于普通邮政地址参见下文的 "强制换行" .强制换行Forced Line Breaks/邮政地址Postal Addresses
<BR> 标记强制产生一个换行,行间没有间隙. 对于由较短的行组成的文本,如邮政地址, <P> 元素产生的附加空行会使你觉得不必要. 例如, 使用 <BR>:National Center for Supercomputing Applications<BR>
605 East Springfield Avenue<BR>
Champaign, Illinois 61820-5518<BR>输出为:
National Center for Supercomputing Applications
605 East Springfield Avenue
Champaign, Illinois 61820-5518
水平线Horizontal Rules
<HR> 标记产生一个和浏览器窗口等宽的水平线. 水平线对于你分割文件中的各个部分非常有用. 例如,非常多人在他们的文本结束和 <address> 信息开始之前加一个水平线.你能改动一条线的尺寸 (粗) 和宽度 ( 水平线延伸长度占窗口的百分比). 你能试着改动设置,直到对显示效果满意. 例如:
<HR SIZE=4 WIDTH="50%">
显示为:
--------------------------------------------------------------------------------
字符格式
HTML 有针对单个字符或句子的两种风格: 逻辑风格和物理风格logical and physical. 逻辑风格Logical styles 根据文本的内容进行标记, 而物理风格 physical styles 指明一个部分的显示效果. 例如, 在前面的句子中, "logical styles" 这个单词标记为一个 "定义definition." 同样的效果 (斜体) 能通过其他的标记告诉你的浏览器 "把这些字变成斜体" 来实现。注意: 有些浏览器对 <DFN> 标记不做所有风格解释, 因此你可能没有发现前面段落中的单词显示成斜体。
逻辑风格和物理风格Logical Versus Physical Styles
如果物理风格和逻辑风格能够产生相同的效果, 为什么不和而为一呢?在最佳的 SGML 概念中, 内容和他的显示是分开的. 因此 SGML 标记一个一级标题字体为一级标题字体, 不过并不指明一级标题字体应该显示多大, 例如, 24点粗体 加倍集中24-point bold Times centered. 这种处理的好处(类似于非常多字处理软件的 style sheets ) 是,如果你决定把一级标记字体改为 20-point left-justified Helvetica, 你只需要改动你的浏览器中一级标题字体的定义就能了. 今天确实有非常多浏览器允许你按你的希望定义多种 HTML 标记在屏幕上的实际效果.
逻辑标签的另一个好处在于他们有助于在你的文件中保持一致性. 标记 <H1> 比 24-point bold Times center 或其他描述要好记得多. 例如, 对 <STRONG> 标记. 多数浏览器用粗体解释. 不过, 某个读者可能喜欢把这部分显示为红色. 逻辑风格提供了这种灵活性.
当然, 假设如果你想用斜体显示一些内容而不想受浏览器的设置的影响, 你就需要使用物理风格 . 因此,物理风格提供一种另一种一致性:在你的文件中用某种方式显示的内容在别的地方也会以同样的方式显示.
你应该固定地使用某一种风格. 如果你用物理风格标记, 则在一篇文件中全都使用物理风格. 如果你使用逻辑风格, 则在文件中坚持使用逻辑风格. 记住,将来的 HTML 可能不再支持物理风格, 这意味着浏览器将不解释物理风格的编码.
[page]逻辑风格Logical Styles
<DFN>
用于被定义的单词. 一般用斜体显示. (NCSA Mosaic is a World Wide Web browser.)
<EM>
用于强调. 通常用斜体显示. (Consultants cannot reset your password unless you call the help line.)
<CITE>
用于书籍的标题, 等. 通常斜体显示. (A Beginner’s Guide to HTML)
<CODE>
用于计算机编码. 用固定宽度字体显示. (The <stdio.h> header file)
<KBD>
用于用户键盘输入. 通常用无格式固定宽度字体显示. (Enter passwd to change your password.)
<SAMP>
用于字母序列. 用固定宽度字体显示. (Segmentation fault: Core dumped.)
<STRONG>
用于着重强调. 通常用粗体显示. (NOTE: Always check your links.)
<VAR>
用于变量, 你将用确定的信息代替这个变量. 通常用斜体显示. (rm filename deletes the file.)
物理风格标记
<B>
粗体文本
<I>
斜体文本
<TT>
打字机文本typewriter text, 如固定宽度文本.
转义序列Escape Sequences (a.k.a. Character Entities)
字符有两种功能:转义特别字符
显示普通 ASCII 字符集中不包含的字符 ( 带有可差别标记的基本字符)
有三个 ASCII 字符--左尖括号(<), 右尖括号 (>), 和ampersand (&)--在 HTML 中有特别含义,因此不能按照原样用在文本中. (尖括号用于指示 HTML 标记的开始和结束, ampersand 用于指示一个转义序列的开始.) 双引号能原样使用,不过也能使用字符实体(").如果在 HTML 文件中使用上述三个字符, you must enter its escape sequence instead:
<
< 的转义序列;
>
> 的转义序列;
&
& 的转义序列;
其他的转义序列支持重读字符, 如:ö
带元音变音的小写字母 o : *
ñ
小写字母n 带 tilde: *
È
大写字母 E 带低重音( grave accent): *
你能用其他字母替代上面的 o, n, 和 E. 参考特别字符清单.注意: 转义序列是区分大小写的,这一点不同于 HTML 的其他部分。例如,你不能用 < 代替 <.
链接 Linking
HTML 的主要长处在于他能够链接文本和/或图象到另一个文件或文件的一部分中. 浏览器用颜色和/或下划线突出指定的文本或图象,以说明他是个超文本链接hypertext link (通常简写为 hyperlink 或 link).HTML 的单个和超文本链接有关的标记为 <A>, 表示 anchor. 在文件中包含 anchor:
用 <A 开始一个 anchor ( A 后面要留一个空白)
指明你要连接的文件:HREF="filename" ,后面个跟一个右尖括号 (>)
输入在当前文件中作为超链文本的部分
输入 anchor 结束标记: </A> ( anchor 结束标记之前不需空白 )
以下是个含有超文本链接到 US.html: 的例子<A HREF="MaineStats.html">Maine</A>
上面的例子中,单词 Maine 被作为指向文件 MaineStats.html的超链,他和第一个文件在同一个目录下.
相对路径名和绝对路径名
你能通过和当前文件的相对路径relative path指明链接到其他目录的文件. 例如, 到 AtlanticStatesa 子目录的文件 NYStats.html 的链接为:<A HREF="AtlanticStates/NYStats.html">New York</A>
他们之所以被称为 相对路径链接 是因为你指定到连接文件的路径是相对于当前文件的位置而言的. 你也能使用文件的绝对路径 (完整的 URL), 不过相对路径在访问一个服务器时效率更高.
路径名使用标准 UNIX 格式. 在 UNIX 格式中,父目录(包含当前目录的目录) 表示为 "..". (更详尽的信息请参考 UNIX 入门参考手册如 Learning the UNIX Operating System from O’Reilly and Associates, Inc.)
假设你在 NYStats.html 文件中,想要参考原始文件 US.html, 你的链接如下:
<A HREF="../US.html">United States</A>
一般地, 你应该使用相对链接,因为:
移动一组文件到另一个位置会比较容易(因为相对路径名依然有效)
和服务器的连接更有效率
需要键入的信息更少
不过,如果指向的文件和当前文件没有直接联系,就需要绝对路径名. 例如, 考虑构成一个用户手册的一组文件. 这组文件内部的链接应该采用相对链接. 而到其他文件的链接 ( 可能指向一个相关的软件) 应该用绝对链接. 这样,当你把用户手册移到一个新目录下时,所有的链接都不必改动.
[page]URLs
World Wide Web 使用标准资源定位 Uniform Resource Locators (URLs) 指明其他服务器中的文件. 一个 URL 包括访问资源的类型(例如, Web, gopher, WAIS), 服务器的地址, 和文件的位置. 语法格式为:scheme://host.domain [:port]/path/ filename
其中 scheme 是以下的一个
file
本地系统的一个文件
ftp
匿名FTP 服务器中的文件
http
World Wide Web 服务器中的文件
gopher
Gopher 服务器中的文件
WAIS
WAIS 服务器中的文件
news
Usenet 的一个新闻组newsgroup
telnet
到一个基于Telnet 的服务的连接
端口port 号通常能省略. (除非对方告诉你使用他,否则忽略他)例如,在你的文件中链接本指南:
<A HREF="http://www.ncsa.uiuc.edu/General/Internet/WWW/HTMLPrimer.html">
NCSA’s Beginner’s Guide to HTML</A>他将文本 NCSA’s Beginner’s Guide to HTML 标记为一个超链,连到当前文件中 .
到指定部分的链接
锚链也能用于引导读者到一篇文件(能是当前文件或其他文件)中的 特定区域,而不一定到缺省的顶端位置. 这种类型的锚链通常称为一个 命名锚链named anchor ,因为创建链接时, 你需要在文件中插入 HTML 名字.本指南是在同一篇文件中使用命名锚链的非常好的例子. 他作成一篇文件以便于打印. 不过当你只是想了解关于HTML 的一部分信息时,在这样一篇(长)文件中浏览是比较费时的. 内部的超链用于在文件开始创建一个"内容索引table of contents". 这些超链使你能从文件中的一个位置移到另一个位置。(到本文的顶端点击内容索引中 到指定部分的链接. 你就会返回这里.)
你还能链接到另一篇文件中的指定部分. 首先提这一点是因为这会有助于帮助你理解一篇文件内部的链接.
不同文件中指定部分之间的链接
假设你想从文件A (documentA.html) 中建立一条到另一篇文件(MaineStats.html)中的一个指定部分的链接.输入HTML编码指向一个命名链接:
documentA.html:
In addition to the many state parks, Maine is also home to
<a href="MaineStats.html#ANP">Acadia National Park</a>.井号(#)后面的字符串能看作文件MaineStats.html 中的一个标签. 这个标签说明了当该链接被激活时浏览器从什么地方开始显示. 在上例中,显示的第一行将是 Acadia National Park heading.
第二步, 在MaineStats.html中创建 命名锚链 (本例中为 "ANP")
<H2><A NAME="ANP">Acadia National Park</a></H2>
这些元素都作好以后,你就能让读者直接找到MaineStats.html中Acadia 的参考信息了.
注意: 要想链接到另一篇文件中的指定位置,你需要对那篇文件具有写权限,或那篇文件中已含有文件内部的命名锚链. 例如,你能在你所写的文件中包含指向本指南的锚链,因为本文中已含有命名锚链 (使用浏览器中的 View Source 看一看编码). 不过如果本文件 没有命名锚链, 你就不能制作到特定位置的链接,因为你不能编辑NCSA服务器中的原始文件.
指向当前文件内指定部分的链接
语法和前文相同,只是文件名 省略.例如, 要从 MaineStats中链接到 ANP :
...More information about <A HREF="#ANP">Acadia National Park</a>
is available elsewhere in this document.注意确保你的文件中在链接指向的部分包含 <A NAME=> 标记(<H2><A NAME="ANP">Acadia National Park</a></H2>).
当你认为读者可能需要打印全部文件,或在一个文件中有非常多短信息需要在线说明的情况下非常有用.
邮件发送Mailto
在超链中包含mailto属性,能方便读者给某个人或别名发送电子邮件. 格式为:<A HREF="mailto:emailinfo@host">Name</a>
例如, 输入:
<A HREF="mailto:pubs@ncsa.uiuc.edu">NCSA Publications Group</a>
能创建一个已设置好的发往 BUPT Publications Group的邮件窗口. (你当然应该换用另一个地址!)
[page]嵌入行中的图象
多数 Web 浏览器能显示嵌入行中的X 位图(XBM), GIF, 或 JPEG 格式的图象(即和文本想邻的图象) . 其他格式的图象正在合并到Web 浏览器中[如, Portable Network Graphic (PNG) 格式]. 每个图象都花费处理时间并降低文件显示的速度. 仔细选择你的文件中的图象和图象的个数.包含一个嵌入行中的图象, 输入:
<IMG SRC=图象名>
ALT="FORWARD" HEIGHT=32 WIDTH=32>其中 图象名 是图象文件的URL .
<IMG SRC> URLs 的语法格式和锚链HREF使用的格式相同. 如果图象文件是GIF 文件, 则图象名中的文件名部分必须以.gif结束. X 位图格式的文件必须以.xbm结尾; JPEG 图象文件必须以.jpg或 .jpeg结束; Portable Network Graphic 文件必须以.png结束.
图象大小属性
在<IMG> 标记中你应该包含其他两个属性,用于通知浏览器正在和文本一起下载的图象的大小. HEIGHT 和 WIDTH 属性使浏览器在下载文件其他部分的时候为图象留出适当的空间(象素). (从你的图象处理软件如Adobe Photoshop中能得到象素大小.)例如, 要在文件中包含一幅自己的肖像, 输入:
<IMG SRC=SelfPortrait.gif HEIGHT=100 WIDTH=65>
ALT="FORWARD" HEIGHT=32 WIDTH=32>注意: 当图象大小和属性描述大小不一致时,有些浏览器使用 HEIGHT 和 WIDTH属性来扩大或缩小一幅图象以使他适用于分配的空间. 并非所有的浏览器研发者都赞同放大/缩小图象. 因此,在安排时不要假设你的读者都能使用这种特性. 最佳查看一下图象大小,使用正确的尺寸.
图象定位
对于图象的显示你具有一定的灵活性. 你能让图象和文本分开,把图象放在左边,右边,或中间. 或你能让图象和文本在同一行。你能尝试多种形式,看一看哪种最佳使图象和文本在同一行
缺省情况下图象的底部和随后的文本在同一行显示,就象目前的这段. 你也能通过把ALIGN= 属性的值设为 TOP 或 CENTER,把图象放到一段的顶端或中间。这段文本和图象的顶端在同一行(<IMG SRC = "BarHotlist.gif" ALIGN=TOP>). 注意只有一行文本如此,其他行跳到图象的底部显示.
这一行文本显示在图象中间(<IMG SRC = "BarHotlist.gif" ALIGN=CENTER>). 同样,只有一行显示在中间,其他行在图象的下面.
不带文本的图象
如果要显示一幅不带文本的图象(例如,你的组织的徽标), 只要把他作为独立的一段即可. 使用段落标记的 ALIGN=属性把图象调整到窗口的中间或右边,如下所示:<p ALIGN=CENTER>
<IMG SRC = "BarHotlist.gif">
</p>结果为:
图象显示在中间; 本段从他下面靠左开始.
图象的替换文本
一些 World Wide Web 浏览器--主要是那些在 VT100 终端上运行的浏览器--不能显示图象. 有些用户会关掉图象下载功能,就算他们的软件能显示图象(特别是如果他们是 modem 或低速线路的用户). HTML 提供一种机制使得读者知道他们看到的页面上缺少了什么.ALT 属性使你能指定一段能替代图象来显示的文本. 例如:
<IMG SRC="UpArrow.gif" ALT="Up">
ALT="" HEIGHT=48 WIDTH=50>其中 UpArrow.gif 是个向上的箭头.在具有图象显示功能并且图象下载打开的浏览器中,你能看到一个上箭头的图像。在VT100 浏览器中或图象下载关闭的情况下, 你的窗口中将显示 Up 这个单词.
你应该对出目前你的文件中的每个图象都使用一个替换文本, 这是一种对读者的礼貌.
背景图象
新版本的 Web 浏览器能下载一幅图象用做显示一个主页时的背景. 有些人喜欢使用背景,有些人不喜欢. 通常,如果你想包含一个背景, 你要确保你的文本在背景上依然能被非常清晰地阅读.背景图象能是个物体的组织 (例如亚麻布纸张)或图象 (可能是个徽标). 你能象生成其他所有图象相同来生成背景图象。
不过你只需要制作一个非常小的图象. 浏览器会使用一种称之为“盖瓦”tiling的特性重复显示这个图象,填满整个浏览器窗口。简单地说,你只要生成一幅图象,浏览器会自动重复多次,直到填满你的窗口。当你使用下面说明的标记时,这个动作会自动执行.
包含背景图象的标记包含在 <BODY> 标记描述中作为一个属性:
<BODY BACKGROUND="filename.gif">
背景颜色
缺省情况下浏览器使用灰底黑字显示文本. 不过, 你能改动他们. 一些 HTML 作者选择一个背景颜色,配以文本颜色的相应改动.对于这种改动一定要预先看一看,是否还易于阅读. (例如, 不少人用黑底红字,非常难以阅读!)
使用<BODY>标记的多种属性,你能改动文本,链接,看过的链接和活动链接的颜色. 例如, 输入:
<BODY BGCOLOR="#000000" TEXT="#FFFFFF" LINK="#9690CC">
将创建一个窗口,背景为黑色 (BGCOLOR), 文本为白色 (TEXT), 超链为银色 (LINK).
六位的数字和字母的组合代表颜色,他给出某种颜色的 RGB (红red, 绿green, 蓝blue)的值. 这个六位数字实际上是三个顺序排列的两位数, 代表从00到FF的红,绿,蓝比重的十六进制值。例如, 000000 表示黑色(没有所有颜色), FF0000 是亮红, FFFFFF 是白色 (所有三种颜色全部饱和). 这些数字和字母的组合的含义是模糊的. 幸运的是有一个在线资源能帮助你了解各种组合和颜色的对应关系:
ColorPro Web server
外部图象,声音,和动画
你可能希望当用户激活你的文件中一个单词或小的图象作成的链接时,把一幅图象作为独立的文件打开. 这种情况称为一个外部图象, 当你不想由于大的图象而降低主文件的下载速度时,他是非常有用的.要包含一个外部图象的链接, 输入:
<A HREF="MyImage.gif">link anchor</A>
你也能用一个小的图象作为到大图象的链接. 输入:
<A HREF="LargerImage.gif"><IMG SRC="SmallImage.gif"></A>
ALT="" HEIGHT=48 WIDTH=50>读者看到图象 SmallImage.gif ,点击他就能打开文件 LargerImage.gif .
使用同样的语法链接外部动画和声音. 唯一的不同在于链接文件的扩展名. 例如,
<A HREF="AdamsRib.mov">link anchor</A>
[page]指明一个到QuickTime 电影的链接. 一些通常的文件类型和其扩展名为:
文件类型 扩展名
纯文本plain text .txt
HTML 文件 .html
GIF 图象 .gif
TIFF 图象 .tiff
X 位图图象 .xbm
JPEG 图象 .jpg 或 .jpeg
PostScript 文件 .ps
AIFF 声音文件 .aiff
AU 声音文件 .au
WAV 声音文件 .wav
QuickTime 电影 .mov
MPEG 电影 .mpeg 或 .mpg记住你假设的读者和他们使用的软件. 例如,多数UNIX 工作站不能播放QuickTime 电影.
表格Tables
在 HTML 制定表格标记之前, HTML 作者不得不在<PRE> 标记中仔细安排他们的表格式的信息,计算空格的个数,预览输出效果。表格不仅对描述表格式信息十分有用,对于那些经常性的 HTML 作者来说,他能使他们能方便地完成大量的 Web 页. (请看 NCSA Relativity Group’s pages ,一个非常好的例子.)根据下面的编码解释考虑你的表格式信息. 一个表格得有一些表头,用于说明每行/列包含什么内容,行rows表示信息, 单元cells表示每个项. 在下面的表格中, 第一列包含表头信息, 每行说明一个 HTML 表格标记, 每个单元含有一对标记或对标记功能的解释.
表格元素
元素 描述
<TABLE> ... </TABLE> 定义一个表格。 如果使用了 BORDER 属性, 浏览器显示一个带边界的表格.
<CAPTION> ... </CAPTION> 定义表格标题的caption . 标题的缺省位置在表格的顶部. 属性 ALIGN=BOTTOM能用于指定标题显示在表格底部
注:caption标记内能使用任意其他标记.
<TR> ... </TR> 说明表格中的一行. 你能定义整个行的缺省属性: ALIGN (LEFT, CENTER, RIGHT) 和/或 VALIGN (TOP, MIDDLE, BOTTOM). 周详内容参考本表格末尾的"表格属性"部分.
<TH> ... </TH> 定义一个表格头单元. 缺省状态该单元的文本为粗体居中. 该单元能包含其他属性,说明单元属性和/或单元内容. 周详内容参见本表格底部的"表格属性"部分.
<TD> ... </TD> 定义一个表格数据单元. 缺省情况下该单元内的文本为水平方向靠左对齐, 垂直方向居中排放. 该单元能包含其他属性,说明单元属性和/或单元内容. 周详内容参见本表格底部的"表格属性"部分.
表格属性
注: 在<TH> ... </TH> 或 <TD> ... </TD> 单元中定义的属性将覆盖( override ) <TR> ... </TR>中的缺省定义.
属性 描述
ALIGN (LEFT, CENTER, RIGHT)
VALIGN (TOP, MIDDLE, BOTTOM)
COLSPAN=n
ROWSPAN=n
NOWRAP
一个单元的水平位置分配.
一个单元的垂直位置分配.
一个单元跨多少列(n).
一个单元跨多少行(n).
关闭一个单元中的自动换行(word wrapping).
通用表格格式
一个表格的通用格式形式为:<TABLE> <== 表格定义的开始
<CAPTION> caption 内容 </CAPTION> <== caption 定义<TR> <== 第一行定义的开始
<TH> 单元cell 内容 </TH> <== 第一行的第一个单元 (一个头head)
<TH> 单元内容 </TH> <== 第一行最后一个单元(一个头 head)
</TR> <== 第一行定义的结尾
<TR> <== 第二行定义的开始
<TD> 单元内容 </TD> <== 第二行第一个单元
....
<TD> 单元内容 </TD> <== 第二行最后一个单元
</TR> <== 第二行定义的结尾
<TR> <== 最后一行定义的开始
<TD> 单元内容 </TD> <== 最后一行第一个单元
...
<TD> 单元内容 </TD> <== 最后一行最后一个单元
</TR> <== 最后一行定义结尾
</TABLE> <== 表格定义结束
<TABLE> 和 </TABLE> 标记必须把整个表格括起. 表格中的第一个项是 CAPTION, 他是可选部分. 然后你能用 <TR> 和 </TR> 标记定义任意多行. 在一行内也能有用<TD>...</TD> 或 <TH>...</TH> 标记定义的任意数目的单元. 表格中的每一行在本质上是和他的上下行独立编排格式的. 这使得你能非常容易地显示象上文中的只有一个单元的表格, 例如表格属性, 跨越表格中的多个列.非表格式信息使用的表格
有些 HTML 作者使用表格描述非表格化信息. 例如, 因为链接能包含在表格单元中, 一些作者使用没有边界的表格组合一些分离的图象创建“一个”图象. 能显示表格的浏览器能无缝隙地显示这些实际分离的图象, 使得合成的图象类似于一个 图象映象image map (一个带有矩形超链区域的图象).使用带有图象边界的表格也能得到非常好的显示效果. 不妨试一试,看看自己喜欢哪种风格.
填充 Form (Fill-out Forms)
Web form 使读者能向 Web 服务器返回信息以产生某种动作. 例如, 假设你想收集名字和电子邮件地址以便向提出需求的读者发送电子邮件. 对每个输入他/她的姓名和地址的人, 你需要得到要发送的信息和加到数据库中的响应者的项目.这种输入数据的处理工作通常是由script(描述式语言:译者注)描述函数或用 Perl 或其他处理文本,文件和信息的语言编写的程式来完成的. 如果你写不出能够处理输入数据的程式或script函数, 你就得找其他人替你完成.
Form 本身倒是比较简单. 他们也使用 HTML 标记来生成. 可能不同的地方在于接受并处理递交数据的程式或script描述函数. 由于需要说明专门的处理输入信息的script描述函数, 在本指南中不讨论 填充forms.
[page]疑难解答
避免标记重叠
请看这个 HTML 例子:<B>This is an example of <DFN>overlapping</B> HTML tags.</DFN>
overlapping 这个单词被同时包含在 <B> 和 <DFN> 两个标记中. 浏览器在这种情况下会无所适从,因而你可能得不到预期的效果.
通常情况下应该避免标记重叠. 检查你的标记,让他们成对出现. 成对使用的标记(显然,结束标记能省略的元素除外, 如段落标记) 中间不应该被打断. 再看看上面的例子. 在中间的标记(DFN)尚未结束前,你不能使粗体标记<B>结束. 在你把文件放入服务器中之前,应该先检查以下是否含有类似上述情况的错误.
只嵌入锚链和字符标记mbed Only Anchors and Character Tags
HTML 协议允许你在其他 HTML 标记中嵌入超链:<H1><A HREF="Destination.html">My heading</A></H1>
不要 在一个锚链中嵌入 HTML 标记:
<A HREF="Destination.html">
<H1>My heading</H1>
</A>尽管当前的多数浏览器能够处理第二个例子, HTML 的正式说明是不支持这种结构的,你的文件也许在将来的浏览器中将发生问题. 记住,一个浏览器显示不正确编码的文件是能被原谅的. 不过这种宽容可能不会延续到该软件的下一个版本!当发生疑问时, 就根据 HTML 说明的规定来书写 (参见下面的 其他信息 ).
字符标记能用在其他元素中改动文本显示模式:
<UL>
<LI><B>A bold list item</B>
<LI><I>An italic list item</I>
</UL>避免嵌入其他类型的 HTML 元素标记. 例如, 你可能想在一个列表中嵌入标题字体以增大一些字符的显示:
<UL>
<LI><H1>A large heading</H1>
<LI><H2>Something slightly smaller</H2>
</UL>尽管有些浏览器能非常好地显示这种编码, 这种格式将来是否有效是非常难说的,因为他是未定义的 . 为了确保对所有浏览器兼容, 你应该避免使用这种结构. (Netscape 支持一种 <FONT> 标记, 用于指定某个字符在浏览器中显示的大小, 也不是当前官方 HTML 说明中的定义.)
在 <LI> 标记中插入 <B> 标记和在 <LI> 标记中插入 <H1> 标记有什么不同呢? 在?TML 语义说明中 <H1> 的含义是个文件中主标题字体的开始,他后面应该跟当前文件的内容. 因此在一个列表中出现 <H1> 时是没有含义的.
字符格式标记通常也不能附加. 例如, 你可能想这样写:
<B><I>some text</I></B>
期望得到一种加粗的斜体文本. 有些浏览器确实能; 另外一些浏览器则只解释最内层的标记.
最后的步骤
使你的编码有效
当你把一篇文件放入一个 Web 服务器时, 要确保格式和每个链接正确(包括命名锚链在内). 最佳的情况是在你认为一篇文件完成了的时候让其他人浏览一遍并且给出评论.你能通过 HTML 有效性服务来验证你的文件是否符合目前普遍接受的 HTML 的标准. 如果你不知道你的文件是否符合 HTML 说明, 这个服务是个有用的教学工具. 这个服务允许你选择一个校验的级别(如, 严格校验strict, 二级校验level 2, 三级校验level 3).如果你想使用一些非标准的格式,这种自由是非常有用的.
替代图像
当<IMG SRC> 标记指向的图像不存在时, 你的浏览器会使用一个替代图像. 在你最后检查你的文件时如果出现了这种情况, 应该确保所指向的图像文件确实存在, 超链使用的 URL 信息正确, 及文件属性被正确设置(对所有人可读). 然后再检查一遍!更新你的文件
如果一个文件的内容是静态的 (例如George Washington的个人传记), 可能不会需要更新. 不过对于和时间关系密切的内容,或包含的领域是经常变化的, 记住不断更新你的文件!当文件含有诸如每周计划或事件的最后期限这一类信息时,更新是非常重要的. 删除过时的文件或注明为什么有些过期的信息依然在服务器中 (例如, 某个事件在下一轮中的需求和当前内容是相同的,所以该文件过一段时间后仍有参考价值).
浏览器的差别
不同的 Web 浏览器显示的 HTML 元素不尽相同. 记住不是所有的浏览器都能够解释 HTML 文件中所有的标记元素. 不过,浏览器对于不能识别的标记通常只是忽略而已.你可能花费了非常多时间是你的文件在你当前使用的浏览器上“看上去非常漂亮”. 如果你用另一个浏览器察看你的文件, 他非常可能看起来不太相同,甚至非常不相同. 因此请记住这个建议:使用正确的 HTML 来书写你的文件. 把解释工作留给浏览器,争取得到最佳的效果.
注释你的文件
在你的HTML文件中你可能需要留一些注释. HTML 中的注释类似于计算机程式中的注释--你输入的文本不是用于给浏览器显示的,读者也无法直接看到他们,就象计算机程式中的注释是不被程式本身使用的,程式使用者也看不到这些注释. 不过,如果读者看原始文件的话,将能看到注释.一般的注释包括更新文件的作者姓名, 生成一个文件所使用的软件和其版本, 或一些较小的改动信息等.
加入一段注释的格式为:
<!-- 注释内容 -->
你必须包含叹号和连字符.
其他信息
本指南只是个关于 HTML 的简介, 而不是个详尽的参考. 下面是一些其他的参考信息. 别忘了先到附近的书店查一查 Web 和 HTML 的书籍.
以上内容由 华夏名网 搜集整理,如转载请注明原文出处,并保留这一部分内容。
“华夏名网” http://www.sudu.cn 和 http://www.bigwww.com 是成都飞数科技有限公司的网络服务品牌,专业经营虚拟主机,域名注册,VPS,服务器租用业务。公司创建于2002年,经过6年的高速发展,“华夏名网”已经成为我国一家知名的互联网服务提供商,被国外权威机构webhosting.info评价为25大IDC服务商之一。 - (阅读次数:450)
- 上一篇: showModelessDialog()使用详解 下一篇: 在 CSS 中关于字体处理效果的思考
- [
收藏] [
推荐] [
评论] [打印本页] [返回上一页][关闭窗口]



