js 去除图片之间的间距

13 篇文章 0 订阅
文章介绍了如何使用Flexbox和Grid布局技术,配合CSS调整,使图片在一行中均匀排列且去除间距。通过设置container为flex-wrap:wrap和调整image元素的宽度、边框等属性,实现在不同屏幕尺寸下适应的图片布局。
摘要由CSDN通过智能技术生成

使用Flexbox 和 Grid 布局,同时去除图片之间的间距。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
  .container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    grid-gap: 0;
  }

  .image {
    width: 100%;
    display: block;
  }
</style>
<title>多张图片一行排列去除间距</title>
</head>
<body>
  <div class="container">
    <img src="./center1.png" alt="Image 1" class="image">
    <img src="./center1.png" alt="Image 2" class="image">
    <img src="./center1.png" alt="Image 3" class="image">
  </div>
</body>
</html>

.container 使用了 Grid 布局来自动填充列,每列的最小宽度是 300px,并且使用了 grid-gap: 0; 来去除间距。.image 设置了宽度为 100% 以充满其容器,并使用 display: block; 来确保图片之间没有额外的空白间隔。

在现有的 Flexbox 布局上稍作调整,通过将 .container 容器设置为 flex-wrap: wrap; 来实现多张图片一行排列并去除图片之间的间距

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
  .container {
    width: 300px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  .image {
    width: calc(33.33% - 2px); /* 计算宽度,并减去边框的宽度 */
    margin: 0; /* 去除默认的外边距 */
    box-sizing: border-box; /* 让边框计入盒模型 */
    border: 1px solid transparent; /* 添加透明边框,用于占位 */
  }

  .image:hover {
    border-color: black; /* 鼠标悬停时显示边框 */
  }
</style>
<title>多张图片一行排列去除间距</title>
</head>
<body>
  <div class="container">
    <img src="./center1.png" alt="Image 1" class="image">
    <img src="./center1.png" alt="Image 2" class="image">
    <img src="./center1.png" alt="Image 3" class="image">
  </div>
</body>
</html>

通过给图片添加了一个透明的边框来占位,同时利用了 calc() 函数计算了每个图片的宽度,并且通过 box-sizing: border-box; 让边框计入盒模型,避免边框增加尺寸。当鼠标悬停在图片上时,边框变为黑色,但这仅是为了演示,你可以根据需要调整边框样式或去除悬停效果。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码海扬帆:前端探索之旅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值