DivCSS布局实例 用dl dt dd来制作列表

CSS网页布局的一大特点就是列表元素的应用,在传统的表格布局中往往将列表元素作为表格来处理,这样的方式非但不具有语义还产生了许多不必要的代码。

  今天我们共同学习一款“图文混排CSS列表”的制作。首先从分析一下此列表的特点,然后编写HTML代码,最终应用CSS样式实现最终的效果。

列表的效果如图所示:
DivCSS布局实例 用dl dt dd来制作列表_第1张图片 

最顶部是栏目名称“我爱CSS 52CSS.com ”与栏目导航“CSS酷站欣赏 DivCSS教程 CSS模板下载”。栏目名称用标题元素Hx来表示,栏目导航可以用ul+li的无序列表。
  下部的三个链接区域形式基本雷同,左侧是图片链接,右侧是文章列表元素。将左侧的图片与文字看成是一个段落,用p标签来表示,右侧的文章列表用ul+li的无序列表。

有了上面的分析开始下面的HTML编码:

 Example Source Code  [www.52css.com]
<div  id="list_52css_com">
        <div  class="list_title"></div>
        <div  class="list_unit"  id="l_showcase"></div>
        <div  class="list_unit"  id="l_article"></div>
        <div  class="list_unit"  id="l_templates"></div>
</div>


  将所有元素置入id为list_52css_com的层中,以便于进行整体布局的控制。在其内部建立四个层,它们分别是:list_title、l_showcase、l_article、l_templates。对于下部的三个内容层,应用同样的class,为list_unit。

下面开始具体深入的编写HTML代码:

 Example Source Code  [www.52css.com]
<div  id="list_52css_com">
        <div  class="list_title">
                <h3><a  href="http://www.52css.com/"  title="我爱CSS">我爱CSS  52CSS.com</a></h3>
                <ul>
                        <li><a  href="http://www.52css.com/css_websites_showcase/"  title="CSS酷站欣赏">CSS酷站欣赏</a></li>
                        <li><a  href="http://www.52css.com/default.asp"  title="DivCSS教程">DivCSS教程</a></li>
                        <li><a  href="http://www.52css.com/css_template/"  title="CSS模板下载">CSS模板下载</a></li>
                </ul>
        </div>
        <div  class="list_unit"  id="l_showcase">
                <p>
                        <a  href="http://www.52css.com/css_websites_showcase/"><img  src="1.jpg"  alt="CSS酷站欣赏"  /></a>
                        <span><a  href="http://www.52css.com/css_websites_showcase/">CSS酷站欣赏</a></span>
                </p>
                <ul>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=100">The  Highland  Fling</a></li>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=99">We  Make  Merch  We  Sell  Merch</a></li>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=98">Kingsfield  Church  Connecting  with  God  Each  Other  and  the  World</a></li>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=97">Adventure  Trekking  in  Nepal</a></li>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=96">Web  Design  Hamilton  -  VO2  Studio</a></li>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=95">We  have  been  doing  strategic  consulting  Digiwize</a></li>
                        <li>·<a  href="http://www.52css.com/css_websites_showcase/view.asp?id=94">Modern  Arboricultural  Services</a></li>
                </ul>
        </div>
        <div  class="list_unit"  id="l_article">
                <p>
                        <a  href="http://www.52css.com/default.asp"><img  src="2.jpg"  alt="DivCSS教程"  /></a>
                        <span><a  href="http://www.52css.com/default.asp">Div  CSS教程</a></span>
                </p>
                <ul>
                        <li>·<a  href="http://www.52css.com/article.asp?id=668">CSS控制Table单元格强制换行与强制不换行  </a></li>
                        <li>·<a  href="http://www.52css.com/article.asp?id=667">DivCSS实例:CSS菜单Flash效果  用图片模拟实现  </a></li>
                        <li>·<a  href="http://www.52css.com/article.asp?id=666">DivCSS布局实例  用dl  dt  dd来制作列表  </a></li>
                        <li>·<a  href="http://www.52css.com/article.asp?id=660">符合web标准的嵌入Flash的方法-JS调用  </a></li>
                        <li>·<a  href="http://www.52css.com/article.asp?id=656">CSS经验:如何管理好样式CSS?  </a></li>
                        <li>·<a  href="http://www.52css.com/article.asp?id=655">DIV  CSS实例:橙蓝互换的CSS翻页效果  </a></li>
                        <li>·<a  href="http://www.52css.com/article.asp?id=650">div  css表单布局技巧及CSS  Form表单设计技巧  </a></li>
                </ul>
        </div>
        <div  class="list_unit"  id="l_templates">
                <p>
                        <a  href="http://www.52css.com/css_template/"><img  src="3.jpg"  alt="CSS模板下载"  /></a>
                        <span><a  href="http://www.52css.com/css_template/">CSS模板下载</a></span>
                </p>
                <ul>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=100">CS模板下载  -  Scuba  Holding</a></li>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=99">CS模板下载  -  Keeping  It  Clean</a></li>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=98">CS模板下载  -  Culture  Shock</a></li>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=97">CS模板下载  -  Simply  CSS</a></li>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=96">CS模板下载  -  Doctors  Office</a></li>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=95">CS模板下载  -  Mint  Chocolate  Chip</a></li>
                        <li>·<a  href="http://www.52css.com/css_template/view.asp?id=94">CS模板下载  -  Andrea  Layout</a></li>
                </ul>
        </div>
        <div  class="clear"></div>
</div>


  在list_title层,置入h3元素作为栏目名称,建立一个ul列表放置栏目导航。
  下部的三个内容层(list_unit),分别置入段落标签p,引入链接图片与文字;建立一个ul放置文章列表。
  在最底部,放置一个类为clear的层来清除浮动。

有了上面的基础开始下面的CSS编码:

 Example Source Code  [www.52css.com]
*  {  margin:0;  padding:0;  font-size:13px;  color:#000;  list-style:none;}
a  {  color:#03c;  text-decoration:none;}
a:hover  {  text-decoration:underline;}
#list_52css_com  {  width:418px;  margin:30px  auto;  border:1px  solid  #999;}


  整体布局声明:
  设置整个层的样式,宽度为418px,上下外边距为30px,左右为自动实现水平居中对齐。边框设置为1px的灰色实线。

 Example Source Code  [www.52css.com]
.list_title  {  width:418px;  height:32px;  border-bottom:1px  solid  #999;  background:#f2f9fd;  overflow:hidden;}
.list_title  h3  {  float:left;  width:160px;  line-height:32px;  text-indent:15px;}
.list_title  h3  a  {  color:#c00;}
.list_title  h3  a:hover  {  color:#03c;}
.list_title  ul  {  float:right;  width:230px;}
.list_title  ul  li  {  float:left;  line-height:32px;  padding:0  5px;}
.list_title  ul  li  a  {  font-size:12px;  color:#333;}


  标题区域list_title层的CSS样式定义:
  设置list_title层宽度与高度分别是:418px、32px;下边框为1px的灰色实线;设置背景色及溢出隐藏。
  栏目名称h3元素向左浮动;宽度160px;行距32px实现文字垂直居中对齐;文本缩进为15px。紧接着设置栏目名称h3链接的样式。
  栏目导航ul列表的CSS样式,向右浮动;宽度为230px;设置列表项li向左浮动;行距为32px;上下内边距为0,左右内边距为5px;紧接着设置链接文字大小与颜色。

 Example Source Code  [www.52css.com]
.list_unit  {  float:left;  width:388px;  margin-left:15px;  padding:15px  0  8px  0;  border-bottom:1px  dotted  #9AC4E9;}
.list_unit  {  display:inline;}


  内容层(list_unit)整体样式定义:
  向左浮动;宽度为388px,左外边距为15px,上内边距15px、下内边距8px;设置下边框为浅蓝色的虚线。
  设置为内联是避免IE的双边距BUG。

 Example Source Code  [www.52css.com]
.list_unit  p  {  float:left;  width:164px;}
.list_unit  p  a  {  display:block;  border:1px  solid  #03c;}
.list_unit  p  a:hover  {  border:1px  dashed  #00f;}
.list_unit  p  a  img  {  width:160px;  height:120px;  margin:1px;  border:0;}
.list_unit  span  {  display:block;}
.list_unit  span  a  {  display:block;  width:164px;  height:22px;  border:0;  line-height:22px;  text-align:center;}
.list_unit  span  a:hover  {  border:0;  color:#c00;}


  内容层(list_unit)内图片链接样式定义:
  整个段落p,向左浮动,宽度为164px。
  设置链接为块元素;设置边框为1px蓝色实线。
  链接悬念状态下,边框变为1px深蓝色虚线。
  链接元素内的图片定义,宽度与高度分别是:160px、120px;外边距为1px;边框为0(消除图片链接浏览器的默认边框)。
  设置链接文字样式,由于上面的设置是整体的,因而在下面的内容中,注意将上面的一些内容层叠掉。
  将span转换为块元素。span内的链接同样转换为块元素,设置宽度与高度分别是164px、22px;设置边框为0(层叠先前的设置);行距设置为22px;文字水平居中对齐。
  span内的链接文字悬停状态下,设置边框为0;颜色设置为#c00;显示下划线。

 Example Source Code  [www.52css.com]
.list_unit  ul  {  float:right;  width:216px;  margin-top:-5px;}
.list_unit  ul  li  {  float:left;  width:216px;  line-height:22px;  color:#039;  white-space:nowrap;  text-overflow:ellipsis;  overflow:hidden;}


  内容层(list_unit)内文章列表样式定义:
  整个列表ul向右浮动;宽度为216px;上外边距为-5px。
  列表项li的CSS样式设置,向左浮动,宽度为216px;行距为22px;颜色为#039;后面的三个属性是实现“截字”效果,52css.com网站上有详细的介绍。(请注意此效果在FF下无效)

 Example Source Code  [www.52css.com]
#l_templates  {  border-width:0;}
.clear  {  clear:both;}


  最后的CSS设置:
  最后一个内容层(list_unit)是没有下边框的,此层的id为l_templates。因而在此进行层叠定义,消除此层的边框即可。
  清除浮动是必须的,否则在FF下可能会出现混乱。这是一个良好的编码实践。

  <<<<<< 我们点击链接观察最终的效果 >>>>>>

  小经验:三个内容层都分别定义了不同的ID,个人认为这是必要的,而且具有很大的扩展性。在最后一个层的下边框设置上,这样的id定义就发挥了作用。如果在以后的发展中,发现DivCSS教程需要去除,可以应用CSS去掉这一模块。在CSS在这样定义就可以了:#l_article { display:none;}

  在此教程中,请注意如何合理的应用HTML标签,建立符合Web标签并具有良好的语义的文档是我们的目标。学习CSS布局不仅在于学习CSS本身,还应该更多的扩展HTML知识与DOM知识。欢迎大家在我的小站留言(http://www.52css.com/),大家共同交流学习,欢迎批评指正。


你可能感兴趣的:(DivCSS布局实例 用dl dt dd来制作列表)