重新认识布局:你真的懂flex吗

本文首发于知乎:https://www.zhihu.com/people/xiao-chong-10-60

1.flex布局,里面的flex项目会脱标吗?
flex布局经常被拿来和浮动比较。但这里要明确:2者都能使得盒子横向排列之外,他们之间几无关联。
浮动的元素会脱标,父元素要有高度,我们得清除浮动。flex布局并不会脱标。这个所有的资料里并没仔细对比,但又很重要。
比如:做一个九宫格,同样的结构,浮动和flex布局的写法不一样,浮动是脱标的,左右,上下的边框加粗的问题,可以用margin负值搞定。看下面的例子,怎么解决边框加粗的问题?水平方向上:margin-left:-1px;竖直方向上:margin-top:-1px;

<!DOCTYPE html>
<html lang="en">

<head>
	<meta charset="UTF-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>Document</title>
	<style>
		/* 任务:做一个九宫格,3*3的样式,每个格子大小为60px*60px */
		* {
			padding: 0;
			margin: 0;
			box-sizing: border-box;
		}

		li {
			list-style: none;
		}

		ul {
			width: 180px;
			height: 180px;
			margin: 10px auto;
		}

		ul li {
			float: left;
			width: 60px;
			height: 60px;
			background-color: pink;
			text-align: center;
			line-height: 60px;
			border: 1px solid #000;
			margin-left: -1px;
			margin-top: -1px;
		}
	</style>
</head>

<body>
	<ul>
		<li>1</li>
		<li>2</li>
		<li>3</li>
		<li>4</li>
		<li>5</li>
		<li>6</li>
		<li>7</li>
		<li>8</li>
		<li>9</li>
	</ul>
</body>

</html>

  


假设我们用flex做呢,边框加粗的问题还能用浮动一样的做法吗?答案是不行。浮动是脱标的,flex并不是,浏览器绘制盒子的过程有区别。水平方向上的边框加粗用margin-left:-1px可以解决,竖直方向上用margin-top:-1px:不行。
怎么办呢,让第二行的上下边框都去掉。

<!DOCTYPE html>
<html lang="en">

<head>
	<meta charset="UTF-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>Document</title>
	<style>
		/* 任务:做一个九宫格,3*3的样式,每个格子大小为60px*60px */
		* {
			padding: 0;
			margin: 0;
			box-sizing: border-box;
		}

		li {
			list-style: none;
		}

		ul {
			display: flex;
			flex-wrap: wrap;
			width: 180px;
			height: 180px;
			margin: 10px auto;
		}

		ul li {
			width: 60px;
			height: 60px;
			background-color: pink;
			text-align: center;
			line-height: 60px;
			border: 1px solid #000;
			margin-left: -1px;
		}

		.second-row {
			border-top: 0;
			border-bottom: 0;
		}
	</style>
</head>

<body>
	<ul>
		<li>1</li>
		<li>2</li>
		<li>3</li>
		<li class="second-row">4</li>
		<li class="second-row">5</li>
		<li class="second-row">6</li>
		<li class="third-row">7</li>
		<li class="third-row">8</li>
		<li class="third-row">9</li>
	</ul>
</body>

</html>

  


2.flex布局,剩余的空间会占满吗?
并不会,剩余的空间分配,主轴上,由子项目的flex属性指定。侧轴会占满父盒子。请看下面的例子:

 

 

 

<!DOCTYPE html>
<html lang="en">

<head>
	<meta charset="UTF-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>Document</title>
	<style>
		.box {
			display: flex;
			width: 1000px;
			height: 200px;
			background-color: pink;
		}

		.box .left {
			width: 200px;
			height: 100px;
			background-color: purple;
		}

		.box .right {
			background-color: skyblue;
		}
	</style>
</head>

<body>
	<div class="box">
		<div class="left">我设置了宽高</div>
		<div class="right">我宽高都没设置</div>
	</div>
</body>

</html>

  

posted @ 2021-06-25 14:47  小虫1  阅读(354)  评论(0编辑  收藏  举报