css图片属性,图片自适应

CSS 图片属性指南:background-size 和 object-fit

在前端开发中,使用图片是非常常见的。为了让图片在网页中显示得更好,CSS 提供了多种属性来调整和控制图片的大小和布局。其中,background-size 和 object-fit 是两个常用的属性,它们可以根据需要调整图片的大小和适应方式。

一、background-size 属性:

background-size 属性用于调整背景图片的大小。它可以使用以下几个值:

1.cover:将背景图像等比缩放并完全覆盖容器,可能会出现部分图像被裁剪的情况。

复制代码
.background{
  background:url('../../assets/1.jpg');
  background-size:cover;
}

2.contain:将背景图像等比缩放并尽量完整地显示在容器内

复制代码
.background{
  background:url('../../assets/1.jpg');
  background-size:contain;
}

3.length:指定背景图像的宽度和高度

复制代码
.background{
  background:url('../../assets/1.jpg');
  background-size:200px 200px;
}

4.percentage:指定背景图像的宽度和高度相对于容器的百分比

复制代码
.background{
  background:url('../../assets/1.jpg');
  background-size:50% 70%;
}

二、object-fit 属性

object-fit 属性用于调整标签中的图片的大小和适应方式。它可以使用以下几个值:

1.fill:将图片拉伸以充满元素,可能会导致图片失真。

复制代码
.img{
  width:100px;
  height:100px;
  object-fit:fill;
}

2.contain:将图片等比缩放并尽量完整地显示在元素中。

复制代码
.img{
  width:100px;
  height:100px;
  object-fit:contain;
}

3.cover:将图片等比缩放并完全覆盖元素,可能会出现部分图像被裁剪的情况。

复制代码
.img{
  width:100px;
  height:100px;
  object-fit:cover;
}

4.scale-down:根据图片的原始尺寸和容器的大小决定图片的大小和适应方式。

复制代码
.img{
  width:100px;
  height:100px;
  object-fit:scale-down;
}

如下代码实现的效果可看出,第三章图片更清晰

复制代码
 <div style="width:100px;height:100px">
       <img style="display:inline-block;width:100%;height:100%" src="../../assets/1.jpg" alt="">
    </div>
     <div style="width:100px;height:100px">
       <img style="display:inline-block;width:100%;height:100%" src="../../assets/2.jpg" alt="">
    </div>
    <div style="width:100px;height:100px">
       <img style="object-fit:cover;width:100px;height:100px" src="../../assets/1.jpg" alt="">
    </div>
    </div>

通过使用 background-size 或 object-fit 属性,我们可以很方便地调整和控制图片的大小和适应方式。

相关推荐
sunny_28 分钟前
💥 Claude Code 源码泄露?我把这个最强 AI Coding Agent 的架构扒干净了
前端·agent·claude
西洼工作室32 分钟前
React轮播图优化:通过延迟 + 动画的组合,彻底消除视觉上的闪烁感
前端·react.js·前端框架
yaaakaaang42 分钟前
(八)前端,如此简单!---五组结构
前端·javascript
我是若尘1 小时前
我的需求代码被主干 revert 了,接下来我该怎么操作?
前端·后端·代码规范
魁首1 小时前
Claude Code 源码泄露的背后,到底与Codex,Gemini 有啥不一样?
前端·openai·claude
攀登的牵牛花1 小时前
程序员失业论,被 SWE-CI 一组数据打醒:真正先被替代的是低质量交付
前端·github
BumBle2 小时前
Vue项目中实现路由守卫自动取消Pending请求
前端
gCode Teacher 格码致知2 小时前
Javascript提高:get和post等请求,对于汉字和空格信息进行编码的原则-由Deepseek产生
开发语言·前端·javascript·node.js·jquery
竹林8182 小时前
从ethers.js迁移到Viem:我在一个DeFi项目前端重构中踩过的坑
前端·javascript
像我这样帅的人丶你还2 小时前
从交稿到甩锅预防:AI 前端流水线
前端·ai编程