扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
设置子菜单项的样式分为3步 1、首先对每个子菜单项,也就是dd元素进行常规设置,包括内外边距清零,设置文字颜色等。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名申请、网络空间、营销软件、网站建设、宏伟网站维护、网站推广。
/* 设置菜单项的dd */
#menu li dd {margin:0;padding:0;color: #fff;
} 2、为了使最后一个dd的下端有一条分割线,我们设置它为1px的红色下边框,这就使之与上边框的红色分割线想对应了,也告诉浏览者这是一块可以点击的区域。
#menu li dd.last {
border-bottom:1px solid #b00;
} 上面的代码也新增了一个last的类,因此我们必须在对应的HTML代码中最后一个dd指定class="last"。
CSS高级教程 3、设置子菜单的链接的样式
#menu li dd a, #menu li dd a:visited {
display:block;
color:#FFF;
text-decoration:none;
padding:5px 20px;
background: #0000FF;}此时,我们在浏览器就可以看到下拉菜单的样式已经可以显示了。 二、设置鼠标经过时的响应
最后一条规则,让鼠标滑过有下拉项的时候,显示下拉菜单。当然我们实际设置的是:如果某一个下拉菜单的父级元素(一级菜单项)被鼠标滑过,那么就让该下拉菜单可以被看见:
#menu li dd { visibility: visible;}
background: #0000FF;}最后我们就可以运行整个文件实现效果了,建站教程网建议大家一起跟着步骤一步一步的做哦。
工具/材料
notepad++
浏览器
打开Notepad++,先输入个页面框架
!DOCTYPE html
html xmlns=""
hade
/hade
body
/body
框架好了,那么就该定义页面的title,关键词keyword,和描述description
meta charset="UTF-8" content="text/html" http-equiv="content-type"
title纯css二级导航下拉菜单/title
meta name="keyword" content="搜狗略懂"
meta name="description" content="描述"
这些内容只能在head/head中完成。
定义页面使用的css样式,也是需要在head里定义的。
style type="text/css"
* {
margin:0;
padding:0;
}
.jiao ul li a:hover{
color:#red;
}
ul, li {
list-style:none;
}
a {
text-decoration:none;
}
.jiao {
border:5px solid #pink;
border-right:none;
overflow:hidden;
float:left;
margin:200px 0 0 600px;
}
.jiao ul li ul li a {
border-right:solid;
border-top:2px dotted #666;
background:#black;
}
.jiaoulli { float:left;}
.jiao ul li a { width:150px; height:80px; text-align:center; line-height:100px; display:block; border-right:5px solid #red; background:#red; color:#red;}
.jiao ul li ul { position:absolute; display:none;}
.jiao ul li:hover ul{ display:block; }
.jiaoulliulli { float:none;}
!--navul只选择nav下一级里面的ul元素
nav ul选择nav内所包含的所有ul元素
navul比nav ul限定更严格,必须后面的元素只比前面的低一个级别。
这里根据你的需求来自己定义。
--
/style
添加一个DIV标签,在页面中划分出一个块来,用来显示。
div中所用的样式为刚才咱们声明的样式“jiao”这个盒子来描述
然后使用无序标签ul+样式li 来实现模块。
div class="jiao"
ul
lia href="#"搜狗略懂/a
ul
lia href="#"搜狗问问/a/li
lia href="#"搜狗输入法/a/li
lia href="#"搜狗浏览器/a/li
lia href="#"搜狐/a/li
/ul
/div
放上全部的代码吧,可以参考一下啊,
!DOCTYPE html
html xmlns=""//允许你通过一个网址来识别你的标记
head
meta http-equiv="Content-Type" content="text/html; charset=utf-8" /
meta name="keyword" content="利用css实现下拉菜单"
meta name="description" content="搜狗略懂、css分享"
titlecss实现下拉导航栏菜单/title
style type="text/css"
* {
margin:0;
padding:0;
}
.jiao ul li a:hover{
color:#red;
}
ul, li {
list-style:none;
}
a {
text-decoration:none;
}
.jiao {
border:5px solid #pink;
border-right:none;
overflow:hidden;
float:left;
margin:200px 0 0 600px;
}
.jiao ul li ul li a {
border-right:solid;
border-top:2px dotted #666;
background:#black;
}
.jiaoulli { float:left;}
.jiao ul li a { width:150px; height:80px; text-align:center; line-height:100px; display:block; border-right:5px solid #red; background:#red; color:#red;}
.jiao ul li ul { position:absolute; display:none;}
.jiao ul li:hover ul{ display:block; }
.jiaoulliulli { float:none;}
!--navul只选择nav下一级里面的ul元素
nav ul选择nav内所包含的所有ul元素
navul比nav ul限定更严格,必须后面的元素只比前面的低一个级别。
这里根据你的需求来自己定义。
--
/style
/head
body
div class="jiao"
ul
lia href="#"搜狗略懂/a
ul
lia href="#"搜狗问问/a/li
lia href="#"搜狗输入法/a/li
lia href="#"搜狗浏览器/a/li
lia href="#"搜狐/a/li
/ul
/li
/ul
/div
/body
/html
如果要添加更多的菜单,只需要后边继续添加ul/li即可
特别提示
写代码过程中一定要记得换行,开头留空,否则过后找东西,连你自己都不知道写的是什么。何谈从哪里找起?
代码粘贴的太复杂;
先给你分析一下原理:二级菜单没有在没有hover属性的情况下是隐藏的所以需要display:none,当鼠标hover的时候二级菜单才会列出来,这是纯css可以实现的;
知道上面的原理之后,下面比较容易实现具体看例子:
HTML代码:
ul
lia href=""一级菜单/a/li
lia href=""一级菜单/a
ul class="drop-ul"
li a href=""二级菜单/a/li
/ul
/li
/ul
CSS代码:
ul li ul.drop-ul{ display: none;position:relative }/*正常情况下隐藏*/
ul li:hover ul.drop-ul li{display: block;} /*当鼠标放上去二级菜单li 显示出来*/
/*这个时候你会发现二级菜单显示的位置可能不对可以使用position属性*/
ul li:hover ul.drop-ul li{position:absolute;}
/*通过top right left 调整位置,根据实际情况调整背景颜色,字体颜色等,细节东西*/
此时可能会发现会二级菜单出现有那么一点点的生硬;没关系配合jquery实现缓慢展现效果
$(document).ready(function() {
if($(window).width() 768) {
$('ul li').hover(
function() {
$('ul', this).stop().slideDown(200);
},
function() {
$('ul', this).stop().slideUp(200);
}
);
}
});
注意不知道jquery的新手使用记住先加载Jquery.min.js文件,放在此段js前面;
参考下面方法
CSS 背景属性(Background)
background
在一个声明中设置所有的背景属性。
1
background-attachment
设置背景图像是否固定或者随着页面的其余部分滚动。
1
background-color
设置元素的背景颜色。
1
background-image
设置元素的背景图像。
1
background-position
设置背景图像的开始位置。
1
background-repeat
设置是否及如何重复背景图像。
1
CSS 边框属性(Border 和 Outline)
border
在一个声明中设置所有的边框属性。
1
border-bottom
在一个声明中设置所有的下边框属性。
1
border-bottom-color
设置下边框的颜色。
2
border-bottom-style
设置下边框的样式。
2
border-bottom-width
设置下边框的宽度。
1
border-color
设置四条边框的颜色。
1
border-left
在一个声明中设置所有的左边框属性。
1
border-left-color
设置左边框的颜色。
2
border-left-style
设置左边框的样式。
2
border-left-width
设置左边框的宽度。
1
border-right
在一个声明中设置所有的右边框属性。
1
border-right-color
设置右边框的颜色。
2
border-right-style
设置右边框的样式。
2
border-right-width
设置右边框的宽度。
1
border-style
设置四条边框的样式。
1
border-top
在一个声明中设置所有的上边框属性。
1
border-top-color
设置上边框的颜色。
2
border-top-style
设置上边框的样式。
2
border-top-width
设置上边框的宽度。
1
border-width
设置四条边框的宽度。
1
outline
在一个声明中设置所有的轮廓属性。
2
outline-color
设置轮廓的颜色。
2
outline-style
设置轮廓的样式。
2
outline-width
设置轮廓的宽度。
2
CSS 文本属性(Text)
color
设置文本的颜色。
1
direction
规定文本的方向 / 书写方向。
2
letter-spacing
设置字符间距。
1
line-height
设置行高。
1
text-align
规定文本的水平对齐方式。
1
text-decoration
规定添加到文本的装饰效果。
1
text-indent
规定文本块首行的缩进。
1
text-shadow
规定添加到文本的阴影效果。
2
text-transform
控制文本的大小写。
1
unicode-bidi
设置文本方向。
2
white-space
规定如何处理元素中的空白。
1
word-spacing
设置单词间距。
1
CSS 字体属性(Font)
font
在一个声明中设置所有字体属性。
1
font-family
规定文本的字体系列。
1
font-size
规定文本的字体尺寸。
1
font-size-adjust
为元素规定 aspect 值。
2
font-stretch
收缩或拉伸当前的字体系列。
2
font-style
规定文本的字体样式。
1
font-variant
规定是否以小型大写字母的字体显示文本。
1
font-weight
规定字体的粗细。
1
CSS 外边距属性(Margin)
margin
在一个声明中设置所有外边距属性。
1
margin-bottom
设置元素的下外边距。
1
margin-left
设置元素的左外边距。
1
margin-right
设置元素的右外边距。
1
margin-top
设置元素的上外边距。
1
CSS 内边距属性(Padding)
padding
在一个声明中设置所有内边距属性。
1
padding-bottom
设置元素的下内边距。
1
padding-left
设置元素的左内边距。
1
padding-right
设置元素的右内边距。
1
padding-top
设置元素的上内边距。
1
CSS 列表属性(List)
list-style
在一个声明中设置所有的列表属性。
1
list-style-image
将图象设置为列表项标记。
1
list-style-position
设置列表项标记的放置位置。
1
list-style-type
设置列表项标记的类型。
1
marker-offset
2
内容生成(Generated Content)
content
与 :before 以及 :after 伪元素配合使用,来插入生成内容。
2
counter-increment
递增或递减一个或多个计数器。
2
counter-reset
创建或重置一个或多个计数器。
2
quotes
设置嵌套引用的引号类型。
2
CSS 尺寸属性(Dimension)
height
设置元素高度。
1
max-height
设置元素的最大高度。
2
max-width
设置元素的最大宽度。
2
min-height
设置元素的最小高度。
2
min-width
设置元素的最小宽度。
2
width
设置元素的宽度。
1
CSS 定位属性(Positioning)
bottom
设置定位元素下外边距边界与其包含块下边界之间的偏移。
2
clear
规定元素的哪一侧不允许其他浮动元素。
1
clip
剪裁绝对定位元素。
2
cursor
规定要显示的光标的类型(形状)。
2
display
规定元素应该生成的框的类型。
1
float
规定框是否应该浮动。
1
left
设置定位元素左外边距边界与其包含块左边界之间的偏移。
2
overflow
规定当内容溢出元素框时发生的事情。
2
position
规定元素的定位类型。
2
right
设置定位元素右外边距边界与其包含块右边界之间的偏移。
2
top
设置定位元素的上外边距边界与其包含块上边界之间的偏移。
2
vertical-align
设置元素的垂直对齐方式。
1
visibility
规定元素是否可见。
2
z-index
设置元素的堆叠顺序。
2
CSS 打印属性(Print)
orphans
设置当元素内部发生分页时必须在页面底部保留的最少行数。
2
page-break-after
设置元素后的分页行为。
2
page-break-before
设置元素前的分页行为。
2
page-break-inside
设置元素内部的分页行为。
2
widows
设置当元素内部发生分页时必须在页面顶部保留的最少行数。
2
CSS 表格属性(Table)
border-collapse
规定是否合并表格边框。
2
border-spacing
规定相邻单元格边框之间的距离。
2
caption-side
规定表格标题的位置。
2
empty-cells
规定是否显示表格中的空单元格上的边框和背景。
2
table-layout
设置用于表格的布局算法。
2
CSS 伪类(Pseudo-classes)
:active
向被激活的元素添加样式。
1
:focus
向拥有键盘输入焦点的元素添加样式。
2
:hover
当鼠标悬浮在元素上方时,向元素添加样式。
1
:link
向未被访问的链接添加样式。
1
:visited
向已被访问的链接添加样式。
1
:first-child
向元素的第一个子元素添加样式。
2
:lang
向带有指定 lang 属性的元素添加样式。
2
CSS 伪元素(Pseudo elements)
:first-letter
向文本的第一个字母添加特殊样式。
1
:first-line
向文本的首行添加特殊样式。
1
:before
在元素之前添加内容。
2
:after
在元素之后添加内容。
参考下面方法
CSS 背景属性(Background)
background
在一个声明中设置所有的背景属性。
1
background-attachment
设置背景图像是否固定或者随着页面的其余部分滚动。
1
background-color
设置元素的背景颜色。
1
background-image
设置元素的背景图像。
1
background-position
设置背景图像的开始位置。
1
background-repeat
设置是否及如何重复背景图像。
1
CSS 边框属性(Border 和 Outline)
border
在一个声明中设置所有的边框属性。
1
border-bottom
在一个声明中设置所有的下边框属性。
1
border-bottom-color
设置下边框的颜色。
2
border-bottom-style
设置下边框的样式。
2
border-bottom-width
设置下边框的宽度。
1
border-color
设置四条边框的颜色。
1
border-left
在一个声明中设置所有的左边框属性。
1
border-left-color
设置左边框的颜色。
2
border-left-style
设置左边框的样式。
2
border-left-width
设置左边框的宽度。
1
border-right
在一个声明中设置所有的右边框属性。
1
border-right-color
设置右边框的颜色。
2
border-right-style
设置右边框的样式。
2
border-right-width
设置右边框的宽度。
1
border-style
设置四条边框的样式。
1
border-top
在一个声明中设置所有的上边框属性。
1
border-top-color
设置上边框的颜色。
2
border-top-style
设置上边框的样式。
2
border-top-width
设置上边框的宽度。
1
border-width
设置四条边框的宽度。
1
outline
在一个声明中设置所有的轮廓属性。
2
outline-color
设置轮廓的颜色。
2
outline-style
设置轮廓的样式。
2
outline-width
设置轮廓的宽度。
2
CSS 文本属性(Text)
color
设置文本的颜色。
1
direction
规定文本的方向 / 书写方向。
2
letter-spacing
设置字符间距。
1
line-height
设置行高。
1
text-align
规定文本的水平对齐方式。
1
text-decoration
规定添加到文本的装饰效果。
1
text-indent
规定文本块首行的缩进。
1
text-shadow
规定添加到文本的阴影效果。
2
text-transform
控制文本的大小写。
1
unicode-bidi
设置文本方向。
2
white-space
规定如何处理元素中的空白。
1
word-spacing
设置单词间距。
1
CSS 字体属性(Font)
font
在一个声明中设置所有字体属性。
1
font-family
规定文本的字体系列。
1
font-size
规定文本的字体尺寸。
1
font-size-adjust
为元素规定 aspect 值。
2
font-stretch
收缩或拉伸当前的字体系列。
2
font-style
规定文本的字体样式。
1
font-variant
规定是否以小型大写字母的字体显示文本。
1
font-weight
规定字体的粗细。
1
CSS 外边距属性(Margin)
margin
在一个声明中设置所有外边距属性。
1
margin-bottom
设置元素的下外边距。
1
margin-left
设置元素的左外边距。
1
margin-right
设置元素的右外边距。
1
margin-top
设置元素的上外边距。
1
CSS 内边距属性(Padding)
padding
在一个声明中设置所有内边距属性。
1
padding-bottom
设置元素的下内边距。
1
padding-left
设置元素的左内边距。
1
padding-right
设置元素的右内边距。
1
padding-top
设置元素的上内边距。
1
CSS 列表属性(List)
list-style
在一个声明中设置所有的列表属性。
1
list-style-image
将图象设置为列表项标记。
1
list-style-position
设置列表项标记的放置位置。
1
list-style-type
设置列表项标记的类型。
1
marker-offset
2
内容生成(Generated Content)
content
与 :before 以及 :after 伪元素配合使用,来插入生成内容。
2
counter-increment
递增或递减一个或多个计数器。
2
counter-reset
创建或重置一个或多个计数器。
2
quotes
设置嵌套引用的引号类型。
2
CSS 尺寸属性(Dimension)
height
设置元素高度。
1
max-height
设置元素的最大高度。
2
max-width
设置元素的最大宽度。
2
min-height
设置元素的最小高度。
2
min-width
设置元素的最小宽度。
2
width
设置元素的宽度。
1
CSS 定位属性(Positioning)
bottom
设置定位元素下外边距边界与其包含块下边界之间的偏移。
2
clear
规定元素的哪一侧不允许其他浮动元素。
1
clip
剪裁绝对定位元素。
2
cursor
规定要显示的光标的类型(形状)。
2
display
规定元素应该生成的框的类型。
1
float
规定框是否应该浮动。
1
left
设置定位元素左外边距边界与其包含块左边界之间的偏移。
2
overflow
规定当内容溢出元素框时发生的事情。
2
position
规定元素的定位类型。
2
right
设置定位元素右外边距边界与其包含块右边界之间的偏移。
2
top
设置定位元素的上外边距边界与其包含块上边界之间的偏移。
2
vertical-align
设置元素的垂直对齐方式。
1
visibility
规定元素是否可见。
2
z-index
设置元素的堆叠顺序。
2
CSS 打印属性(Print)
orphans
设置当元素内部发生分页时必须在页面底部保留的最少行数。
2
page-break-after
设置元素后的分页行为。
2
page-break-before
设置元素前的分页行为。
2
page-break-inside
设置元素内部的分页行为。
2
widows
设置当元素内部发生分页时必须在页面顶部保留的最少行数。
2
CSS 表格属性(Table)
border-collapse
规定是否合并表格边框。
2
border-spacing
规定相邻单元格边框之间的距离。
2
caption-side
规定表格标题的位置。
2
empty-cells
规定是否显示表格中的空单元格上的边框和背景。
2
table-layout
设置用于表格的布局算法。
2
CSS 伪类(Pseudo-classes)
:active
向被激活的元素添加样式。
1
:focus
向拥有键盘输入焦点的元素添加样式。
2
:hover
当鼠标悬浮在元素上方时,向元素添加样式。
1
:link
向未被访问的链接添加样式。
1
:visited
向已被访问的链接添加样式。
1
:first-child
向元素的第一个子元素添加样式。
2
:lang
向带有指定 lang 属性的元素添加样式。
2
CSS 伪元素(Pseudo elements)
:first-letter
向文本的第一个字母添加特殊样式。
1
:first-line
向文本的首行添加特殊样式。
1
:before
在元素之前添加内容。
2 :after 在元素之后添加内容。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流