css布局中margin为0,但依然有间距

2022-11-24 0 14

在进行布局时经常会出现,div与div之间虽然设置为了margin: 0px ,但是依然有间距的问题。

html部分代码如下:

<body>
	<div class="main">
		<div class="content">
			<div class="Sbox">
				<div class="boximg"><img src="img/1.jpg"></div>
				<div class="boxtext"><p>Batman</p></div>
			</div>
			<div class="Sbox">
				<div class="boximg"><img src="img/2.jpg"></div>
				<div class="boxtext"><p>Eminem</p></div>
			</div>
			<div class="Sbox">
				<div class="boximg"><img src="img/3.jpg"></div>
				<div class="boxtext"><p>Skrillex</p></div>
			</div>
			<div class="Sbox">
				<div class="boximg"><img src="img/4.jpg"></div>
				<div class="boxtext"><p>Hearthstone</p></div>
			</div>
			<div class="Sbox">
				<div class="boximg"><img src="img/5.jpg"></div>
				<div class="boxtext"><p>HigherBrother</p></div>
			</div>
		</div>
	</div>
</body>

css部分代码

.content {
	background-color: lightblue;
	width: 900px;
	padding: 20px;
	text-align: center;
}
.Sbox {
	background-color: white;
	display: inline-block;
	width: 200px;
	height: 140px;
	padding: 10px 0px;
	font-size: 14px;
	margin: 0px;
}

可以看到虽然设置了各个盒子之间的间距为0px,但是在浏览器中显示出来依然有间距,打开控制台审查元素也显示没有东西占据了宽度啊,这是什么问题呢?难道是浏览器问题?然而其实浏览器并没有问题,有问题的只是我们的代码!!!

在html中,我们每个div之间有缩进,这里的缩进,其实就是空格或者回车,是一个字符!!!浏览器会认为你在每个div直接加了一个空格,所以即使你的margin为0,但是它中间依旧有间隔,所以就会出现上图的情况。

那应该怎么办呢?难道是去掉缩进?我们不可以不要缩进啊,那样代码可读性就太差了,那应该怎么解决这个问题呢?其实很简单,我们在 .content 中加上这样一个样式

.content {
	background-color: lightblue;
	width: 900px;
	padding: 20px;
	text-align: center;
        font-size: 0px;
}

打开浏览器,就可以发现,它就已经合并在一起了,因为我们把字体大小设置为了0px,也就不再占据宽度了。

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!cheeksyu@vip.qq.com
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有积分奖励和额外收入!
5.严禁将资源用于任何违法犯罪行为,不得违反国家法律,否则责任自负,一切法律责任与本站无关

发表评论
暂无评论