我是网络开发的新手(实际上是昨天开始的),我不知道如何做以下事情:我想安排无序列表的元素('内联块&# 39; -ed)以便将文本定位在"中间"像素大于文本的图像。
例如:
类似我尝试过使用" float"和"位置:亲戚",但没有什么真正帮助我。 我怎么能这样做?
我的代码如下"菜单":
<div class="header">
<div class="navbar">
<ul>
<li>Home</li>
<li>Something</li>
<li><img src="\assets\img\logo.png" class="logo"></img></li>
<li>Contact</li>
<li>About</li>
</ul>
</div>
</div>
提前致谢!
答案 0 :(得分:2)
您可以使用FlexBox这是CSS的新功能,它有助于以简单的方式创建布局和管理布局项之间的空间
li {
display: inline-block;
padding: 10px;
}
img {
width: 100px;
height: 100px;
}
ul {
display: flex;
align-items: center;
}
&#13;
<div class="header">
<div class="navbar">
<ul>
<li>Home</li>
<li>Something</li>
<li><img src="\assets\img\logo.png" class="logo" /></li>
<li>Contact</li>
<li>About</li>
</ul>
</div>
</div>
&#13;
编辑:
Fun game I used to learn FlexBox
尽管Flexbox在大多数现代浏览器中运行良好,但您可能需要添加前缀以支持旧版浏览器。 Browser Support for FlexBox
答案 1 :(得分:0)
您可以将<li>
项的行高设置为与菜单相同的高度:
.navbar ul {
height: 50px;
}
.navbar ul li {
height: 50px;
line-height: 50px;
}
答案 2 :(得分:0)
您可以使用flexbox来定位元素。
body {
font-family: sans-serif;
}
ul {
list-style-type: none;
display: flex;
flex-direction: row;
padding: 0;
margin: 0;
}
li {
display: flex;
flex: 1;
flex-direction: column;
justify-content: center;
text-align: center;
transition: .4s all;
}
li:hover {
background: #eee;
}
img {
width: 100px;
height: 100px;
margin: 0 auto;
}
&#13;
<div class="header">
<div class="navbar">
<ul>
<li>Home</li>
<li>Something</li>
<li><img src="http://placehold.it/100/100" class="logo" /></li>
<li>Contact</li>
<li>About</li>
</ul>
</div>
</div>
&#13;
答案 3 :(得分:0)
*{
font-family:"arial";
font-size:12px;
}
ul,li{
list-style:none;
}
.header{
width:100%;
float:left;
}
.navbar{
float:left;
margin:0px;
padding:0px;
}
li {
float:left;
width : auto;
line-height : 50px;
height : 50px;
/* border : 1px blue solid; */
padding:0px 2px;
}
li span {
display : -moz-inline-box; /* FF2 or lower */
display : inline-block; /* FF3, Opera, Safari */
line-height : normal;
vertical-align : middle;
}
li span { *display : inline;} /* haslayout for IE6/7 */
<div class="header">
<div class="navbar">
<ul>
<li><span>Home</span></li>
<li><span>Something</span></li>
<li><span><img src="http://via.placeholder.com/50x50" class="logo"></img></span></li>
<li><span>Contact</span></li>
<li><span>About</span></li>
</ul>
</div>
</div>
答案 4 :(得分:0)
我认为这就是你要找的东西。跑吧。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>HTMLiveCode</title>
<style type="text/css">
body {height: 100%; width: 100%; background: #000;}
body .header {height: 100px; width: 100%;}
body .header .navbar,
body .header .navbar ul{height: 100%; width: 100%; display: flex; padding: 0; margin:0; background: #fff; display: table;}
body .header .navbar ul li {display: table-cell; vertical-align: middle; width: 20%; text-align: center}
body .header .navbar ul li img{vertical-align: middle;}
</style>
<script type="text/javascript">
</script>
</head>
<body>
<div class="header">
<div class="navbar">
<ul>
<li>Home</li>
<li>Something</li>
<li><img src="\assets\img\logo.png" class="logo"></img></li>
<li>Contact</li>
<li>About</li>
</ul>
</div>
</div>
</body>
</html>