导航栏-- HTML中的<UL>标签中li横向排列

第一步、编写横向菜单的HTML代码架构

请将以下代码添加到HTML文档的导航栏区域中。

<ul id="menu">
 <li><a href="http://www.baidu.com">Baidu.Com</a></li>
 <li><a href="http://www.Code52.Net">Code52.Net</a></li>
 <li><a href="http://www.yahoo.com">Yahoo.Com</a></li>
 <li><a href="http://www.google.com" class="last">Google.Com</a></li>
</ul>

第二步、编写CSS代码

1、设置公共样式

请将以下CSS代码添加到HTML文档的<head>...</head>标签范围中。

<style type="text/css">
#menu { 
font:12px verdana, arial, sans-serif; /* 设置文字大小和字体样式 */
}
#menu, #menu li {
list-style:none; /* 将默认的列表符号去掉 */
padding:0; /* 将默认的内边距去掉 */
margin:0; /* 将默认的外边距去掉 */
}
</style>

大家都知道,<ul>中的各条目<li>默认都是纵向排列的,我们需要定义CSS来让其横向排列起来。

Tips:因为我们现在将导航栏拉出来独立讲解,所以需要设置一些公共样式,如果您在 body 或其他地方已经重设了默认效果,以上代码可以去掉

2、让文字横排

大家都知道,<ul>标签下的项目<li>默认是纵向排列的,我们需要定义额外的CSS属性让其横向排列。

<style type="text/css">
#menu li { 
float:left; /* 往左浮动 */
}
</style>

3、设置链接样式:

<style type="text/css">
#menu li a {
display:block; /* 将链接设为块级元素 */
padding:8px 50px; /* 设置内边距 */
background:#3A4953; /* 设置背景色 */
color:#fff; /* 设置文字颜色 */
text-decoration:none; /* 去掉下划线 */
border-right:1px solid #000; /* 在左侧加上分隔线 */
}
</style>

我们用内边距(即填充padding)的方式,让每个菜单变得宽一些,如果你的菜单是中英文混排的,建议设置单个菜单的高宽,这样可以避免中英文字符行高不一致导致的高度误差。设置固定高度的方式:

<style type="text/css">
#menu li a {
display:block; /* 将链接设为块级元素 */
width:150px; /* 设置宽度 */
height:30px; /* 设置高度 */
line-height:30px; /* 设置行高,将行高和高度设置同一个值,可以让单行文本垂直居中 */
text-align:center; /* 居中对齐文字 */
background:#3A4953; /* 设置背景色 */
color:#fff; /* 设置文字颜色 */
text-decoration:none; /* 去掉下划线 */
border-right:1px solid #000; /* 在左侧加上分隔线 */
}
</style>

4、链接悬停效果:

通过以上几步的综合作用,一个横向导航栏的初步框架就出现了。此步主要是定义链接的悬停效果,让导航栏更美观。当然,如果要让导航栏更炫丽,你可以在CSS悬停属性上定义背景图片。

<style type="text/css">
#menu li a:hover {
background:#146C9C; /* 变换背景色 */
color:#fff; /* 变换文字颜色 */
}
</style>

这里的代码一个缺陷,最右边会多出来一个边框,由于 :first-child 伪类不被IE系列浏览器所支持,我们只能单独写一个样式,将最后一个边框去掉,同时要给 HTML 代码增加一个额外选择符。

<ul id="menu">
<li><a href="http://www.baidu.com">Baidu.Com</a></li>
<li><a href="http://www.Code52.Net">Code52.Net</a></li>
<li><a href="http://www.yahoo.com">Yahoo.com</a></li>
<li><a href="http://www.google.com" class="last">Google.com</a></li>
</ul>

<style type="text/css">
#menu li a.last {
border-right:0; /* 去掉左侧边框 */
}
</style>

好了,到这里一个简单的横向导航菜单就制作完成了,是不是很简单? 下面给出完整代码:

<style type="text/css">
#menu { 
 font:12px verdana, arial, sans-serif; 
}
#menu, #menu li {
 list-style:none;
 padding:0;
 margin:0;
}
#menu li { 
 float:left; 
}
#menu li a {
 display:block;
 /* 如果是中英文混排的文字,建议用固定宽度
 width:150px;
 height:30px;
 line-height:30px;
 text-align:center;
 */
 padding:8px 50px;
 background:#3A4953;
 color:#fff;
 text-decoration:none;
 border-right:1px solid #000;
}
#menu li a:hover {
 background:#146C9C;
 color:#fff;
 text-decoration:none;
 border-right:1px solid #000;
}
#menu li a.last {
 border-right:0; /* 去掉左侧边框 */
}
</style>

<ul id="menu"> <li><a href="http://www.baidu.com">Baidu.Com</a></li> <li><a href="http://www.Code52.Net">Code52.Net</a></li> <li><a href="http://www.yahoo.com">Yahoo.com</a></li> <li><a href="http://www.google.com" class="last">Google.com</a></li> </ul>

你可以查看我们制作的在线演示和下载本文提供的实例包。

上面的CSS样式,我修改了一下。如下:

<style type="text/css">
#menu {
font-size: 12px;
font-weight: bolder;
}
#menu li{
list-style-image: none;
list-style-type: none;
background-color: #999999;
border-right-width: 1px;
border-right-style: solid;
border-right-color: #000000;
float: left;
}
#menu li a{
color: #FFFFFF;
text-decoration: none;
margin: 0px;
padding-top: 8px;
display: block; /* 作为一个块 */
padding-right: 50px; /* 设置块的属性 */
padding-bottom: 8px;
padding-left: 50px;
}
#menu li a:hover{
background-color: #0099CC;
}

</style>

### 回答1: 在CSS,要让无序列表(ul)的各个子项(li横向排列,可以使用以下方法: 1. 将 ul 标签添加 display: flex; 的样式,使其成为弹性容器。 2. 将 ul 的子项 li 添加 flex 属性,设置为 1,使每个子项都有相同的宽度。 3. 将 ul 的子项 li 添加 margin-right 属性,用于控制每个子项之间的距离。 4. 可以采用 "伪元素+margin负值" 的方式去掉最后一个子项的 margin-right,确保不会因为最后一项的 margin 造成排列不正常。 5. 若 ulli 元素有 padding,可以通过对 ul 的 padding 和 li 的 box-sizing 属性进行调整,使子项横排布局更紧凑。 以上就是将 ul li 横向排列的几个关键步骤,需要根据实际需求灵活调整样式。 ### 回答2: 在CSS,想要将ul li横向排列,需要使用display属性。通过改变display属性的值,可以实现不同的布局方式。 一、使用行内布局 将ul的display属性值设置为inline-block,li的display属性值也设置为inline-block,则li将会在同一行内水平排列代码示例: ul { display: inline-block; } li { display: inline-block; } 二、使用浮动布局 将li的float属性设置为left,则li会向左浮动,从而实现水平排列代码示例: li { float: left; } 如果使用浮动布局,需要清除浮动。可以在ul添加一个空元素,给它设置clear属性为both,让ul的高度自适应。 代码示例: ul:after { content: ""; display: block; clear: both; } 三、使用flex布局 使用CSS3的flex布局可以更方便地实现水平排列,只需要给ul添加display: flex属性即可。 代码示例: ul { display: flex; } li { flex: 1; /* 控制每个li的宽度相等 */ } 上述三种方式都可以实现横向排列的效果,具体采用何种方式,可根据实际情况选择。 ### 回答3: CSSul li横向排列是Web开发非常常见的布局方式之一,它可以用于创建水平的导航栏标签页、图片墙等多种场景。 要实现ul li横向排列,我们需要使用CSS的display属性。默认情况下,ulli元素都被设置为块级元素,即按照垂直方向排列。但是,我们可以通过调整display属性,将它们转换为行内元素或者浮动元素来实现横向排列。 具体来说,实现ul li横向排列的步骤如下: 1. 首先,我们可以为ul元素设置display为flex或者inline-block,来将其转换为行内块元素。 2. 然后,我们需要为li元素设置display为inline-block或者float为left/right,以便它们可以水平排列。 3. 最后,我们可以对ulli元素设置padding和margin等样式,以控制它们的间距和样式。 具体的代码示例如下: ``` ul { display: flex; /* 或者inline-block */ list-style: none; padding: 0; margin: 0; } ul li { display: inline-block; /* 或者float: left/right */ padding: 10px; margin-right: 10px; background-color: #ccc; } ``` 上面的代码将创建一个横向排列ul元素,其每一个li元素都有10px的内边距和外边距,并且背景颜色为灰色。通过添加更多的CSS样式,我们可以进一步美化并调整它们的样式和位置,从而获得所需的布局效果。 总之,CSSul li横向排列是一种非常有用的布局技巧,掌握它可以方便我们创建各种类型的水平布局组件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值