dl、dt、dd 标记来改造163邮箱的广告条

所属分类: 网页制作 / CSS 阅读数: 828
收藏 0 赞 0 分享
打开网易邮箱的登录界面,我们会发现,在首页的底部有这样一个“最新动态”的广告条,其设计代码如下: HTML代码

[Ctrl A 全部选择 提示:你可先修改部分代码,再按运行]
在这里,网易采用了table来设计这个页面效果,当然<table>用在这里并没有什么不妥。但是今天,我们主要是想用一个非<table>方法来达到同样的效果。
首先看一下用到的背景图
这张图片中包含了所有该页面中用到的图片,在这个横条中只用到了底部了两个,我们可以看出,对于长度远小于实际内容的背景来说,使用<table>有很多便利性。
接下来我们看看怎么用非<table>标签来达到同样的效果:首先,从主义上来看“最新动态”是标题,其它后面几项都是“最新动态的详细内容”,存在主次关系。这个至少可以想到一点就是“最新动态”可能用到<hn>标签;其次,各内容之间的并列关系,对于处理并列关系我们常用的就是无序列表<ul>了;最后,结合上面的主次与并列,我们可以考虑用<dl><dt><dd>来实现这个效果了(关于这三个标签的具体含义和应用请参考“ 经常被遗忘的重要标签——<dl><dt><dd>”)。
  1. *{padding:0;margin:0;font-size:12px;font-family:Tahoma"宋体"} dl{background:#E1F6FFurl(attachments/month_0712/g2007123002932.gif)no-repeat0px-259px;float:left;padding-left:5px;margin:100px0100px;}/*设定背景位置,设定背景不重复*/
  2. dt{height:26px;line-height:26px;float:left;background:RGB(187,228,246);padding:05px;}/*向左浮动,以期dt和dl内容在在同一行内*/ dd{padding-left:20px;height:26px;line-height:26px;background:#E1F6FFurl(attachments/month_0712/g2007123002932.gif)no-repeat-230px-300px;display:inline;float:left}/*为每个dd设定样式,当然在有些情况下可以使用list-style-type,但这里似乎行不通*/
  3. .first{padding-left:16px;background:#E1F6FFurl(attachments/month_0712/g2007123002932.gif)no-repeat-8px-259px;}/*设定first的特殊样式*/ .last{padding-left:40px;padding-right:20px;background:#E1F6FF;background:url(attachments/month_0712/g2007123002932.gif)no-repeat-17px-259px;}


* {padding:0;margin:0;font-size:12px;font-family:Tahoma "宋体"}
dl {background:#E1F6FF url(attachments/month_0712/g2007123002932.gif) no-repeat 0px -259px;float:left;padding-left:5px; margin:100px 0 100px;} /*设定背景位置,设定背景不重复*/
dt {height:26px;line-height:26px;float:left;background:RGB(187,228,246);padding:0 5px;}/*向左浮动,以期dt和dl内容在在同一行内*/
dd {padding-left:20px; height:26px;line-height:26px;background:#E1F6FF url(attachments/month_0712/g2007123002932.gif) no-repeat -230px -300px;display:inline;float:left}/*为每个dd设定样式,当然在有些情况下可以使用list-style-type,但这里似乎行不通*/
.first {padding-left:16px;background:#E1F6FF url(attachments/month_0712/g2007123002932.gif) no-repeat -8px -259px;}/*设定first的特殊样式*/
.last {padding-left:40px;padding-right:20px;background:#E1F6FF;background:url(attachments/month_0712/g2007123002932.gif) no-repeat -17px -259px;}
  1. <dl>
  2. <dt>最新动态</dt> <ddclass="first"></dd>
  3. <ddheight="26">100%有奖!白金情侣项链等你拿</dd> <dd>出门在外,紧急邮件处理不了怎么办?</dd>
  4. <dd>打造中国最好的收费邮箱</dd> <ddclass="last"></dd>
  5. </dl>

<dl>
<dt>最新动态</dt>
<dd class="first"></dd>
<dd height="26">100%有奖!白金情侣项链等你拿</dd>
<dd>出门在外,紧急邮件处理不了怎么办?</dd>
<dd>打造中国最好的收费邮箱</dd>
<dd class="last"></dd>
</dl>
运行上面的效果,我们可以看到两者大体相似。
当然,本例存在一个问题就是<dd class="first"></dd>和<dd class="last"></dd>是两个为了实现我们想要的效果而存在的,并无实在的语义,因此这也是本例的一个缺点。不过我相信,应该有更好的不使用<table>标签实现此类问题办法。
更多精彩内容其他人还在看

CSS配合JavaScript做酷的动态页面效果

  利用CSS配合JavaScript的可以做很多更酷的动态页面效果,在本教程的最后给大家简单介绍一下CSS配合JS的应用。首先,要搞清楚事件和动作的概念。在客户端脚本中,JavaScript 通过对事件进行响应来获得与用户的交互。例如,当用户单击一个按钮或者在某段文字上移动鼠标
收藏 0 赞 0 分享

WEB标准,Web前端开发工程师必备技术列表

  想要打造并拥有一流的Web产品开发团队,在团队成员基础能力上一定要下功夫。对于Web前端产品开发来说,仅仅掌握Web1.0时代简单的"网页套接"是完全不够的。我结合自己的团队配备,特此罗列了Web前端产品工程师所涉及的技能列表如下:   通过许多实际项目,
收藏 0 赞 0 分享

用CSS制作Alpha滤镜测试板

alpha滤镜给制作网页特效提供了较大的创作空间,但由于它控制参数较多,在实际应用时,为了确定一组合适的参数值,不得不反复调整修改,在编辑窗口和预览窗口来回倒腾,甚是麻烦,本文介绍了一种简单的方法。制作一个“Alpha滤镜参数测试板”,在测试板上输入参数
收藏 0 赞 0 分享

非常流行的所谓的气泡窗口

普通的Alt无法自定义风格,而Sweet Titles通过JS脚本与CSS的集合.自定义了这种伪Alt风格. 前一段时间非常流行的,就所谓的气泡窗口(鼠标移到链接处出现的). 我们这里实现的用的是Sweet Titles的插件.显示效果完全由CSS控制.. 先下载Sweet Ti
收藏 0 赞 0 分享

CSS教程:li和ul标签用法举例

LI代码的格式化: A).运用CSS格式化列表符: ul li{ list-style-type:none; } B).如果你想将列表符换成图像,则: ul li{ list-style-type:none; list-style-image: url(/blog/images/
收藏 0 赞 0 分享

CSS教程:CSS中的定位(position)

  使用CSS来定位页面内层的位置,一直是比较难以掌握的事情,很多时候,往往被绝对定位的元素,总是以浏览器的左上角为坐标原点,此时,如果浏览器的大小改变,被定义的层就会偏离设计想要的位置,让人很挠头。   其实,要想控制好层的绝对定位,只要理解CSS中关于定位
收藏 0 赞 0 分享

CSS教程:盒模型(BOX Model)

  如果想熟练掌握DIV和CSS的布局方法,首先要对盒模型有足够的了解。每个HTML元素都可以看作一个装了东西的盒子,盒子里面的内容到盒子的边框之间的距离即填充(padding),盒子本身有边框(border),而盒子边框外和其他盒子之间,还有边界(margin),如图1所示。
收藏 0 赞 0 分享

无延迟翻滚的图形与CSS混合风格按钮

  在一个具有图形背景的按钮中添加CSS风格的文本,这种建立按钮的方法结合了具有CSS翻滚(CSS rollover)标记的开发速度和效率,从而有效地提高按钮外表图像的三维效果。   相比于常规的图形按钮,这些图形/CSS混合按钮可易于建立和载入,因为你只需要为空白按钮外面
收藏 0 赞 0 分享

css里expression实现界面对象的批量控制

用过css样式我们就知道, 可以定义一批对象的class属性来指定同一个样式来统一界面. 但如何统一同类型的对象的事件? 比如:界面有无数个 <img src="**.jpg"> 如何实现鼠标经过此图片, 图片的src变成是**_over.jpg?
收藏 0 赞 0 分享

CSS教程:水平对齐(text-align)

  水平对齐(text-align),用以设定元素内文本的水平对齐方式。   1.语法   text-align具体参数如下: 语法:text-align:left|right|center|justify 说明:设定元素内文本的水平对齐方式。 参数:left:左
收藏 0 赞 0 分享
查看更多