让图片适应标签的CSS object-fit属性

news2024/9/22 10:08:09

在实际的项目运行过程中,可能出现运营人员上传的文件与预期的图片尺寸不同的情况,为了解决这一问题可以使用 object-fit 属性,对嵌入的图像(以及其他替代元素,如视频)做相应的变化,更加精确地控制图像的展示效果,从而满足多样化的设计需求。

让图片适应标签的CSS object-fit属性

  • 1 说明
  • 1.1 被变化图片的原图
  • 1.2 区域说明
  • 2 object-fit: none
  • 3 object-fit: fill
  • 4 object-fit: contain
  • 5 object-fit: cover
  • 6 object-fit: scale-down
  • 7 示例所有代码

object-fit: fill|contain|cover|scale-down|none;

1 说明

1.1 被变化图片的原图

为了更好的观察object-fit对于图片的改变,可以先查看原图的效果。
1416x708像素
在这里插入图片描述

77x66像素
在这里插入图片描述

1.2 区域说明

黑色部分像素300px × 300px
图片img标签200px × 200px

2 object-fit: none

object-fit:none; 保留原有元素内容的长度和宽度,不对图片进行变化。
图片的中心会自动对准img标签的中心位置。
这种情况下:大图只显示一部分;小图尺寸不变正常显示。
在这里插入图片描述

3 object-fit: fill

object-fit:fill; 是object-fit的默认属性,不保持纵横比缩放图片,使图片的宽高完全拉伸至填满 img 标签。
这种情况下:大图被缩小变形;小图被放大、变形、失真。
在这里插入图片描述

4 object-fit: contain

object-fit:contain; 保持图片原有比例,将保证图片的长边可以被完整的显示出来,图片会被缩放。
这种情况下:大图被缩小;小图被放大;
在这里插入图片描述

5 object-fit: cover

object-fit:cover; 保持原有比例,使图片短边能被显示出来,多余部分内容不被显示。
这种情况下:大图长边被裁剪;小图被放大,长边被裁剪;
在这里插入图片描述

6 object-fit: scale-down

object-fit:scale-down; 保持原有比例。内容的尺寸与 none 或 contain 中的一个相同,取决于它们两个之间谁得到的对象尺寸会更小一些。
这种情况下:大头被缩小,使长边能显示出来;小图长宽无编号。
在这里插入图片描述

7 示例所有代码

<!DOCTYPE html>
<html lang="zh">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .box {
        width: 900px;
        height: auto;
        display: grid;
        grid: auto-flow 300px / repeat(3, 300px);
        column-gap: 5px;
        row-gap: 20px;
        margin: 0 auto;
      }

      .box > div {
        display: grid;
        place-items: center;
        place-content: center;
        background: #000;
      }

      .box > div > span {
        color: #fff;
        min-height: 30px;
        text-align: center;
        margin-top: 10px;
      }

      .box > div > img {
        width: 200px;
        height: 200px;
        background: #aaa;
      }
    </style>
  </head>

  <body>
    <div class="box">
      <div>
        <span>图片原尺寸大于img标签尺寸</span>
        <img src="./image/big.jpg" alt="" srcset="" style="object-fit: none" />
      </div>
      <div>
        <span>object-fit:none; 保留原有元素内容的长度和宽度。</span>
        <span>这种情况下:</span>
        <span>大图只显示一部分</span>
        <span>小图正常显示,但是留白很大</span>
      </div>
      <div>
        <span>图片原尺寸小于于img标签尺寸</span>
        <img
          src="./image/small.jpg"
          alt=""
          srcset=""
          style="object-fit: none"
        />
      </div>
      <div>
        <span>图片原尺寸大于img标签尺寸</span>
        <img src="./image/big.jpg" alt="" srcset="" style="object-fit: fill" />
      </div>
      <div>
        <span
          >object-fit:fill;
          默认属性,不保持纵横比缩放图片,使图片的宽高完全拉伸至填满 img
          元素</span
        >
        <span>这种情况下:</span>
        <span>大图被缩小、变形</span>
        <span>小图被放大、变形、失真</span>
      </div>
      <div>
        <span>图片原尺寸小于于img标签尺寸</span>
        <img
          src="./image/small.jpg"
          alt=""
          srcset=""
          style="object-fit: fill"
        />
      </div>

      <div>
        <span>图片原尺寸大于img标签尺寸</span>
        <img
          src="./image/big.jpg"
          alt=""
          srcset=""
          style="object-fit: contain"
        />
      </div>
      <div>
        <span
          >object-fit:contain;
          保持图片原有比例,将保证图片的长边可以被完整的显示出来,图片会被缩放。</span
        >
        <span>这种情况下:</span>
        <span>大图被缩小</span>
        <span>小图被放大</span>
      </div>
      <div>
        <span>图片原尺寸小于于img标签尺寸</span>
        <img
          src="./image/small.jpg"
          alt=""
          srcset=""
          style="object-fit: contain"
        />
      </div>

      <div>
        <span>图片原尺寸大于img标签尺寸</span>
        <img src="./image/big.jpg" alt="" srcset="" style="object-fit: cover" />
      </div>
      <div>
        <span
          >object-fit:cover;
          保持原有比例,使图片短边能被显示出来,多余部分内容不被显示。</span
        >
        <span>这种情况下:</span>
        <span>大图长边被裁剪</span>
        <span>小图被放大,长边被裁剪</span>
      </div>
      <div>
        <span>图片原尺寸小于于img标签尺寸</span>
        <img
          src="./image/small.jpg"
          alt=""
          srcset=""
          style="object-fit: cover"
        />
      </div>

      <div>
        <span>图片原尺寸大于img标签尺寸</span>
        <img
          src="./image/big.jpg"
          alt=""
          srcset=""
          style="object-fit: scale-down"
        />
      </div>
      <div>
        <span
          >object-fit:scale-down; 保持原有比例。内容的尺寸与 none 或 contain
          中的一个相同,取决于它们两个之间谁得到的对象尺寸会更小一些。</span
        >
        <span>这种情况下:</span>
        <span>大图被缩小,是长边能被显示出来</span>
        <span>小图长宽无变化</span>
      </div>
      <div>
        <span>图片原尺寸小于于img标签尺寸</span>
        <img
          src="./image/small.jpg"
          alt=""
          srcset=""
          style="object-fit: scale-down"
        />
      </div>
    </div>
  </body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1527426.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构 二叉树 力扣例题AC——代码以及思路记录

LCR 175. 计算二叉树的深 某公司架构以二叉树形式记录&#xff0c;请返回该公司的层级数。 AC int calculateDepth(struct TreeNode* root) {if (root NULL){return 0;}else{return 1 fmax(calculateDepth(root->left), calculateDepth(root->right));} } 代码思路 …

WPF连接MySqldemo

界面总要管理数据嘛,于是便学习了一下WPF与MySql的基本连接. 运行结果: 环境配置 需要下载安装Mysql,网上教程很多,不详说,创建的工程需要下载或者引入相关的包(MySql.Data) 连接的部分直接看具体的代码即可 xaml代码(只放置了一个按钮和文本框) <Grid><Button x:Name…

Android下的匀速贝塞尔

画世界pro里的画笔功能很炫酷 其画笔配置可以调节流量&#xff0c;密度&#xff0c;色相&#xff0c;饱和度&#xff0c;亮度等。 他的大部分画笔应该是通过一个笔头图片在触摸轨迹上匀速绘制的原理。 这里提供一个匀速贝塞尔的kotlin实现&#xff1a; class EvenBezier {p…

hadoop分布式环境搭建

准备三台centos虚拟机 。&#xff08;master&#xff0c;slave1&#xff0c;slave2&#xff09; (hadoop、jdk文件链接&#xff1a;https://pan.baidu.com/s/1wal1CSF1oO2h4dkSbceODg 提取码&#xff1a;4zra) 前四步可参考hadoop伪分布式环境搭建详解-CSDN博客 1.修改主机名…

pycharm里test connection连接成功,但是无法同步服务器文件,deployment变灰

如果服务器test connection连接成功&#xff0c;但是无法同步文件。 可以尝试以下方式&#xff1a; 点击tools-deployment-browse remonte host&#xff0c;选择要连接的服务器的文件夹 如果能正常显示服务器文件夹&#xff0c;再点击tools-deployment&#xff0c;注意要把要…

B002-springcloud alibaba 微服务环境搭建

目录 创建父工程创建基础模块创建用户微服务创建商品微服务创建订单微服务微服务调用 创建父工程 新建项目springcloud-alibaba&#xff0c;本工程不需要写代码&#xff0c;删除src 导包 <parent><groupId>org.springframework.boot</groupId><artifact…

redis设计与实现(二)——持久化

1. 前言&#xff1a; redis是一个基于内存是键值对数据库&#xff0c;但是并非把数据存入内存就高枕无忧了。为了应对可能出现的进程中止&#xff0c;断电等意外情况&#xff0c;redis提供了持久化功能把数据持久化到硬盘。 2. RDB持久化 2.1. rdb文件的创建 rdb通过创建二…

智能合约 - 部署ERC20

Remix介绍 Remix是一个由以太坊社区开发的在线集成开发环境&#xff08;IDE&#xff09;&#xff0c;旨在帮助开发者编写、测试和部署以太坊智能合约。它提供了一个简单易用的界面&#xff0c;使得开发者可以在浏览器中直接进行智能合约的开发&#xff0c;而无需安装任何额外的…

借助Aspose.html控件,在 C# 中更改 HTML 边框颜色

在这篇博文中&#xff0c;我们将学习如何在 C# 中更改 HTML 边框颜色。本指南将为您提供使用 C# 以编程方式有效更改 HTML 文件中的边框颜色、CSS 边框颜色、 HTML表格边框颜色等所需的知识和技能。 Aspose.Html 是一种高级的HTML操作API&#xff0c;可让您直接在.NET应用程序…

Linux TCP参数——tcp_adv_win_scale

文章目录 tcp_adv_win_scaleip-sysctl.txt解释buffering overhead内核缓存和应用缓存示例计算深入理解从2到1(tcp_adv_win_scale的值)总结 tcp_adv_win_scale adv-advise&#xff1b;win-window; 用于指示TCP中接收缓存比例的值。 static inline int tcp_win_from_space(int …

【Unity每日一记】unity中的内置宏和条件编译(Unity内置脚本符号)

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;uni…

放慢音频速度的三个方法 享受慢音乐

如何让音频慢速播放&#xff1f;我们都知道&#xff0c;在观看视频时&#xff0c;我们可以选择快进播放&#xff0c;但是很少有软件支持慢速播放。然而&#xff0c;将音频慢速播放在某些情况下是非常必要的。例如&#xff0c;当我们学习一门新语言时&#xff0c;我们可以将音频…

C语言(排序、逆序、计算天数、矩阵转置)

一、对10个整数排序&#xff08;从小到大&#xff09;。例如原来 a[0]~a[9]的值为 6 90 45 56 1 15 44 78 58 101&#xff0c;排完序后a[0]~a[9]的值变为 1 6 15 44 45 56 58 78 90 101。 #include<stdio.h> int main() {int i,j,t;int a[10]{6,90,…

量子加速超算简介

量子加速超算简介 有用的量子计算的发展是全球政府、企业和学术界的巨大努力。 量子计算的优势可以帮助解决世界上一些与材料模拟、气候建模、风险管理、供应链优化和生物信息学等应用相关的最具挑战性的问题。 要实现量子计算的优势&#xff0c;需要将量子计算机集成到现有的…

SpringBoot+Redis实现分布式WebSocket

什么是分布式WebSocket&#xff1f; 是指在分布式系统架构中实现WebSocket的通信机制&#xff0c;它允许在不同的服务器节点之间共享和同步WebSocket会话状态&#xff0c;从而实现跨多个服务器的实时消息传递。 在分布式环境中实现WebSocket的挑战主要包括以下几点&#xff1a…

mac npm install 很慢或报错

npm ERR! code CERT_HAS_EXPIRED npm ERR! errno CERT_HAS_EXPIRED npm ERR! request to https://registry.npm.taobao.org/pnpm failed, reason: certificate has expired 1、取消ssl验证&#xff1a; npm config set strict-ssl false 修改后一般就可以了&#xff0c;…

BootScrap详细教程

文章目录 前言一、BootScrap入门二、导航三、栅格系统四、container五、面板六、媒体对象七、分页八、图标九、实现动态效果 前言 BootScrap是别人帮我们写好的CSS样式。如果想要使用BootScrap&#xff0c;需要先下载下来&#xff0c;在页面上引入&#xff0c;编写HTML需要按照…

【实验01 扩展实验】C#桌面项目:简易计算器

【实验要求】 &#xff08;1&#xff09;新建一个C#桌面项目Calc&#xff0c;实现简易计算器功能&#xff0c;界面如图1所示。 &#xff08;2&#xff09;计算方式&#xff1a;通过点击对应的按钮&#xff0c;输入第1个数&#xff08;可以是整数或实数&#xff09;&#xff0c…

配置LVS NAT模式

配置LVS NAT模式 环境准备 client1&#xff1a;eth0->192.168.88.10&#xff0c;网关192.168.88.5lvs1: eth0 -> 192.168.88.5&#xff1b;eth1->192.168.99.5web1&#xff1a;eth1->192.168.99.100&#xff1b;网关192.168.99.5web2&#xff1a;eth1->192.168…

【推荐】免费AI论文写作-「智元兔 AI」

还在为写论文焦虑&#xff1f;免费AI写作大师来帮你三步搞定&#xff01; 智元兔AI是ChatGPT的人工智能助手&#xff0c;并且具有出色的论文写作能力。它能够根据用户提供的题目或要求&#xff0c;自动生成高质量的论文。 不论是论文、毕业论文、散文、科普文章、新闻稿件&…