日期:2013-08-14 浏览次数:21008 次
W3C组织(www.w3c.org)定义的新的HTML 4.0规范给每一个网页设计者带来了更强大的工具,这是一项影响所有网络开发者和设计者的变化,许多在过去想都不敢想的动态效果,如今借助于DHTML和CSS可以轻而易举地实现,这里就网页编制过程中一些效果的实现加以详述,希望您能够借以活跃一下您的网页。
* 菜单技术
访问过Microsoft和Macromedia站点的人如果细心的话,一定会留意到其中的菜单技术,点击一下出现子菜单,再点一下隐去子菜单,很是风趣和实用。笔者分别下载了这两个页面,在对源码进行分析之后,发现他们用的并不是同一种方法,而且两种方法各有利弊,下面让我们来看一下他们都是如何实现的。
Macromedia 采用的是多页技术。就是先做一个没有展开项的主菜单的页面,然后分别制造每一个主菜单项展开后的页面,主菜单有多少项,就得做多少个子页面与之绝对应。下面我们举个简单的例子加以说明:
<html>
<head>
<title>A menu example</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body bgcolor="#FFFFFF">
<a name="abc"></a><p>
<a href="menu_2.htm#abc"><b>Click here!</b></a>
</body>
</html>
<html>
<head>
<title>A menu example</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body bgcolor="#FFFFFF">
<p><a name="abc"></a></p>
<p><a href="menu_1.htm#abc">
<b>Click here!</b></a> </p>
list 1
list 2
list 3
</body>
</html>
点击图1中的Click here!就会出现图2的效果。具体实现时,一定要留意标签<a name=" ">的定义和使用,要做到逐一对应,否则就会乱套。另外,当菜单项很多时,记住只要当前列出的子菜单处用<a name=" ">来定义,别的主菜单项应分别链接到它相应展开的页面去。
这种方法实现得很简单,普通人很快就能掌握,而且任何浏览器均可支持,但它的缺点也是明显的。首先是慢,来回调用各个页面必然带来长时间的等待,只要页面上都是文字时,才感觉不到停滞;再就是编制困难,虽然技术简单,但是一个一个地制造实在是有点麻烦。因此,这种技术还是有一定的局限性的。
Microsoft采用的是DHTML技术。DHTML是比较新的技术,因此对于一些“陈旧”的浏览器来说,这种菜单实现方式就无能为力了。
我们还是举个例子来说明一下。
如图3,单击 Product & Services 立刻就出现了下面的菜单,再点一下又隐去了,和Macromedia的一样,不同的是仿佛快了许多,它的源代码如下。
<html>
<head>
<meta HTTP-EQUIV="Content-Type" content="text/html; charset=iso-8859-1">
<title>Welcome to Microsoft's Homepage</title>
<style TYPE="text/css">
.NV1 {font-family:Arial;font-weight:bold;font-size:.9em;cursor:hand;margin-top:10;text-indent: -14;margin-left: 14;}
.NV2 {position:relative;font-size:.9em;font-weight:normal;}
</style>
</head>
<body>
<script TYPE="text/javascript">
function clikker(a,b) {
if (a.style.display ==') {
a.style.display = 'none';
b.src='http://edu.cnzz.cn/NewsInfo/usm.gif';
}
else {
a.style.display=';
b.src='http://edu.cnzz.cn/NewsInfo/http://edu.cnzz.cn/NewsInfo/dsmh.gif';
}
}
</script>
<div CLASS="NV1" ID="BB" >
<dd><img ID="BBp" SRC="http://edu.cnzz.cn/NewsInfo/http://edu.cnzz.cn/NewsInfo/dsmh.gif" ALT="*" ALIGN="MIDDLE" BORDER="0&