css案例学习之ul li dl dt dd实现二级菜单

简介:

效果

代码实现

复制代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>二级菜单</title>
<style type="text/css">



/* 整体设置*/ 
#menu {
    margin:0; 
    padding:0;
    width:610px;
    list-style-type:none; 
    font:14px Arial; 
    }

#menu li {
    float:left; 
    padding:0; 
    margin:0 1px 0 0; 
    width:150px;
    }

/* 设置菜单项*/
#menu li dl { 
    width:150px;/*ie6*/
    margin: 0; 
    padding: 0 0 10px 0; 
    background: #cb6 url(images/bottom.gif) no-repeat bottom left; 
    }


#menu li dt a,#menu li dd a{ display:block;}


/* 设置菜单项的dt */
/* 设置菜单项的dt */
#menu li dt { 
    margin:0; 
    padding: 5px; 
      text-align:center;
    border-bottom:1px solid #b00;
    background:#ed8 url(images/top.gif) no-repeat top left;
    }



#menu li dt a ,#menu li dt a:visited {
    display:block; 
    color:#333;
    text-decoration:none;
    }

    
/* 设置菜单项的dd */
#menu li dd { 

    margin:0; 
    padding:0; 
    color: #fff; 
    background: #47a; 
    }

#menu li dd.last {
    border-bottom:1px solid #b00;
    }

#menu li dd a, #menu li dd a:visited {
height:1em;
    display:block; 
    color:#fff; 
    text-decoration:none; 
    padding:4px 5px 4px 20px;
    background: #47a url(images/arrow.gif) no-repeat 10px 10px; 
    }    
    
/*关闭子菜单*/

#menu li dd { display:none;}

/* 设置鼠标响应 */



#menu li:hover dd  { display:block;}

#menu li dd a:hover {
    background: #147; 
    color:#9cf;
    }


</style>
</head>

<body>
    <ul id="menu">
        <li>
            <dl>
                <dt><a href="#">Artech Studio</a></dt>
                <dd><a href="#">Web Dev</a></dd>
                <dd><a href="#">Web Design</a></dd>
                <dd><a href="#">Books</a></dd>
                <dd class="last"><a href="#">Contact Us</a></dd>
            </dl>    
        </li>
        <li>
            <dl>
                <dt><a href="#">Artech Store</a></dt>
                <dd><a href="#">Books</a></dd>
                <dd><a href="#">DVDs</a></dd>
                <dd><a href="#">Movies</a></dd>
                <dd class="last"><a href="#">Service</a></dd>
            </dl>    
        </li>
        <li>
            <dl>
                <dt><a href="#">Artech Achi</a></dt>
                <dd><a href="#">Landscape</a></dd>
                <dd><a href="#">Plan</a></dd>
                <dd><a href="#">Design</a></dd>
                <dd class="last"><a href="#">Maps</a></dd>
            </dl>    
        </li>
        <li>
            <dl>
                <dt><a href="#">Artech Science</a></dt>
                <dd><a href="#">Physics</a></dd>
                <dd><a href="#">Maths</a></dd>
                <dd><a href="#">Chemistry</a></dd>
                <dd class="last"><a href="#">Courses</a></dd>
            </dl>    
        </li>
    </ul>
</body>
</html>
复制代码

针对ie6进行后期优化

复制代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>二级菜单</title>
<style type="text/css">



/* 整体设置*/ 
#menu {
    margin:0; 
    padding:0;
    width:610px;
    list-style-type:none; 
    font:14px Arial; 
    }

#menu li {
    float:left; 
    padding:0; 
    margin:0 1px 0 0; 
    width:150px;
    }

/* 设置菜单项*/
#menu li dl { 
    width:150px;/*ie6*/
    margin: 0; 
    padding: 0 0 10px 0; 
    background: #cb6 url(images/bottom.gif) no-repeat bottom left; 
    }

#menu li dt a,#menu li dd a{ display:block;}

/* 设置菜单项的dt */
#menu li dt { 
    margin:0; 
    padding: 5px; 
      text-align:center;
    border-bottom:1px solid #b00;
    background:
    }

#menu li dt.orange { background:#fa5 url(images/top.gif) no-repeat top left;}
#menu li dt.yellow { background:#ee5 url(images/top.gif) no-repeat top left;}
#menu li dt.green  { background:#5e5 url(images/top.gif) no-repeat top left;}
#menu li dt.blue   { background:#5cf url(images/top.gif) no-repeat top left;}

#menu li dt a ,#menu li dt a:visited {
    display:block; 
    color:#333;
    text-decoration:none;
    }

/* 设置菜单项的dd */
#menu li dd { 

    margin:0; 
    padding:0; 
    color: #fff; 
    background: #47a; 
    }

#menu li dd.last {
    border-bottom:1px solid #b00;
    }

#menu li dd a, #menu li dd a:visited {
    display:block; 
    color:#fff; 
    text-decoration:none; 
    padding:4px 5px 4px 20px;
    background: #47a url(images/arrow.gif) no-repeat 10px 10px; 
    height:1em;
    }

/*关闭子菜单*/

#menu li dd { display:none;}

/* 设置鼠标响应 */



#menu li:hover dd , #menu li a:hover dd { display:block;}

#menu li:hover, #menu li a:hover { border:0;}/*ie6*/

#menu li dd a:hover {
    background: #147; 
    color:#9cf;
    }
    
/*针对ie6的设置*/    
#menu table { border-collapse:collapse; 
    padding:0; 
    margin:-1px; 
    font-size:1em;
    }
    
    
</style>
</head>

<body>
    <ul id="menu">
        <li>
            <!--[if lte IE 6]><a href="#nogo"><table><tr><td><![endif]-->
            <dl>
                <dt class="orange"><a href="#">Artech Studio</a></dt>
                <dd><a href="#">Web Dev</a></dd>
                <dd><a href="#">Web Design</a></dd>
                <dd><a href="#">Books</a></dd>
                <dd class="last"><a href="#">Contact Us</a></dd>
            </dl>    
        <!--[if lte IE 6]></td></tr></table></a><![endif]-->
        </li>
        <li>
            <!--[if lte IE 6]><a href="#nogo"><table><tr><td><![endif]-->
            <dl>
                <dt class="yellow"><a href="#">Artech Store</a></dt>
                <dd><a href="#">Books</a></dd>
                <dd><a href="#">DVDs</a></dd>
                <dd><a href="#">Movies</a></dd>
                <dd class="last"><a href="#">Service</a></dd>
            </dl>    
        <!--[if lte IE 6]></td></tr></table></a><![endif]-->
        </li>
        <li>
            <!--[if lte IE 6]><a href="#nogo"><table><tr><td><![endif]-->
            <dl>
                <dt class="green"><a href="#">Artech Achi</a></dt>
                <dd><a href="#">Landscape</a></dd>
                <dd><a href="#">Plan</a></dd>
                <dd><a href="#">Design</a></dd>
                <dd class="last"><a href="#">Maps</a></dd>
            </dl>    
        <!--[if lte IE 6]></td></tr></table></a><![endif]-->
        </li>
        <li>
            <!--[if lte IE 6]><a href="#nogo"><table><tr><td><![endif]-->
            <dl>
                <dt class="blue"><a href="#">Artech Science</a></dt>
                <dd><a href="#">Physics</a></dd>
                <dd><a href="#">Maths</a></dd>
                <dd><a href="#">Chemistry</a></dd>
                <dd class="last"><a href="#">Courses</a></dd>
            </dl>    
        <!--[if lte IE 6]></td></tr></table></a><![endif]-->
        </li>
    </ul>
</body>
</html>




本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/5007682.html,如需转载请自行联系原作者
相关文章
|
3月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
上下文选择器(迭代选择器):基于祖先或同胞元素选择一个元素 ID和类选择器:基于id#和class的属性值进行选择元素。 属性选择器:基于属性的有无和特征进行选择。 ①上下文选择器: 上下文选择器的语法格式:标签1 标签2{属性:值;} //注意:组合选择器和上下文选择器的区别,组合选择器以逗号隔开, 上下文选择器以空格隔开 ②特殊的上下文选择器 子选择器> : 语法格式:标签1>标签2 解释说明:标签1和标签2
283 1
|
3月前
|
前端开发 JavaScript 算法
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
transition过渡属性 早期在Web中要实现动画效果,都是依赖于JavaScript或Flash来完成。 但在CSS3中新增加了一个新的模块transition,它可以通过一些简单的CSS事件来触发元素的外观变化, 让效果显得更加细腻。简单点说,就是通过鼠标经过、获得焦点,被点击或对元素任何改变中触发, 并平滑地以动画效果改变CSS的属性值。 在CSS中创建简单的过渡效果可以从以下几个步骤来实现: 在默认样式中声明元素的初始状态样式; 声明过渡元素最终状态样式,比如悬浮状态; 在默认样式中通过添加
252 1
|
3月前
|
前端开发 JavaScript 算法
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
transform变形 css3在原来的基础上新增了变形和动画相关属性,通过这些属性可以实现以前需要大段JavaScript才能实现的 功能。 CSS3的变形功能可以对HTML组件执行位移、旋转、缩放、倾斜4种几何变换,这样的变换可以控制HTML组件 呈现出丰富的外观。 借助于位移、旋转、缩放、倾斜这4种几何变换,CSS3提供了transition动画。 transition动画比较简单,只要指定HTML组件的哪些CSS属性需要使用动画效果来执行变化,并指定动画时间,就可保证动画播放。 比transitio
200 0
|
4月前
|
前端开发 JavaScript
HTML/CSS/JavaScript基础学习day03-作业
本教程通过多个实例讲解JavaScript中for循环的常见用法,包括遍历数组、元素加1、求最大值/最小值、计算平均值、过滤偶数及字符串拼接等操作,并附有代码示例和运行结果图。
75 3
|
4月前
|
前端开发 JavaScript 算法
HTML/CSS/JavaScript基础学习day03-作业
本内容包含多个 JavaScript 编程示例,涵盖数组遍历、条件筛选、字符串处理、数值计算等常见操作,适合练习基础算法与逻辑思维。
119 5
|
4月前
|
前端开发 JavaScript
HTML/CSS/JavaScript基础学习day02-作业
本教程介绍了JavaScript基础编程练习,包括使用for循环打印数字、判断奇偶数、计算总和以及用if语句判断正数的方法。每部分均配有示例代码和运行结果图,帮助初学者理解循环与条件判断的应用。最后通过思维导图回顾所学内容,强化知识点记忆。
89 2
|
7月前
|
存储 自然语言处理 前端开发
抖音快手小红书虚拟评论截图生成器,模拟对话制作工具,html+js+css
这是一款纯前端实现的多平台虚拟评论生成器,支持抖音、快手、小红书风格,适用于产品演示与UI设计。采用Vanilla JS与Flexbox布局,利用IndexedDB存储数据,CSS Variables切换主题。
|
7月前
|
存储 前端开发 安全
病历单生成器在线制作,病历单生成器app,HTML+CSS+JS恶搞工具
本项目为医疗病历模拟生成器,旨在为医学教学和软件开发测试提供数据支持,严格遵守《医疗机构病历管理规定》。
|
7月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
7月前
|
前端开发 容器
处方单图片生成器, 处方单在线制作免费,js+css+html恶搞神器
这是一个电子处方模拟生成系统,使用html2canvas库实现图片导出功能。系统生成的处方单包含多重防伪标识,并明确标注为模拟数据,仅供学习