如何在HTML + CSS中排列不同列表的元素?

时间:2018-02-01 09:29:04

标签: html css

我是网络开发的新手(实际上是昨天开始的),我不知道如何做以下事情:我想安排无序列表的元素('内联块&# 39; -ed)以便将文本定位在"中间"像素大于文本的图像。

例如:

From this我希望与this

类似

我尝试过使用" 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>

提前致谢!

5 个答案:

答案 0 :(得分:2)

您可以使用FlexBox这是CSS的新功能,它有助于以简单的方式创建布局和管理布局项之间的空间

&#13;
&#13;
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;
&#13;
&#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;
}

https://jsfiddle.net/m042aec0/

答案 2 :(得分:0)

您可以使用flexbox来定位元素。

&#13;
&#13;
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;
&#13;
&#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>