图片超过容器溢出的几种解决方法(实现图片缩放)

网页插入图片的两种常见应用场景

在网页编写,我们经常会插入图片来优化网页整体结构,增强用户体验感,在插入图片时,我们会有两种比较常见的应用场景,一种就是使用background-image属性插入背景图片,还有一种是使用img标签插入图片

使用background-image属性插入背景图片

当插入的 background-image 与容器尺寸不符时,可以通过 CSS 的 background-size 属性来调整背景图像的大小以适应容器。以下是一些常见的解决方案:

1. 使用 background-size: cover;
较为推荐,不影响图片比例,可能失去部分图片内容

扩展或缩放背景图像以完全覆盖容器,同时保持图像的纵横比。这可能会导致图像的某些部分在容器内不可见。

.container {width: 500px;height: 300px;background-image: url('image.jpg');background-size: cover;background-position: center; /* 可选,使图像居中 */
}

2. 使用 background-size: contain
较为推荐,不影响图片比例,可能会让容器留下部分空白

这将缩放背景图像以完全适应容器,保持图像的完整可见性,但可能会在容器的某些部分留下空白。

.container {width: 500px;height: 300px;background-image: url('image.jpg');background-size: contain;background-repeat: no-repeat; /* 可选,防止图像重复 */background-position: center; /* 可选,使图像居中 */
}

3. 使用指定尺寸`

精准把控,可能会影响图片比例,比较麻烦
可以使用像素值或百分比来明确设置背景图像的大小。

.container {width: 500px;height: 300px;background-image: url('image.jpg');background-size: 500px 300px; /* 设置具体的宽和高 */
}

4. 使用百分比适应
较为摆烂的一种方法,会改变图片比例,但是确实一劳永逸

.container {width: 500px;height: 300px;background-image: url('image.jpg');background-size: 100% 100%; /* 宽度和高度都设置为容器的100% */
}

注意,如果图像的原始纵横比与容器的纵横比不同,使用 background-size: 100% 100%; 可能会导致图像变形。为了避免这种情况,通常建议使用 covercontain 值,或者通过调整容器的尺寸来保持图像的原始纵横比。

如果想要更精细地控制背景图像在容器中的位置和显示方式,可以结合使用 background-positionbackground-repeat 等属性。

如果容器内的内容(如文本或其他元素)需要与背景图像保持一定的位置关系,可能还需要使用额外的 CSS 布局技巧,如定位(positioning)或弹性盒模型(flexbox)等。

使用img标签插入图片

当img标签里的图片尺寸超过其外部容器尺寸时,有几种方法可以处理这个问题:

1.使用CSS的max-width和height属性:

比较推荐,可以保证图片比例,可以根据图片时横图还是竖图来确定让width还是heightauto

你可以设置图片的max-width为100%,这样图片的最大宽度就不会超过其容器的宽度。同时,为了保持图片的宽高比,可以省略height属性或者将其设置为auto

.myImg {  max-width: 100%;  height: auto;  
}

这样,图片会根据其容器的宽度自动缩放,同时保持其原始的宽高比。


2. 使用object-fit属性:

比较推荐,保留图片比例,但要注意选择cover还是contain

如果你需要更精确地控制图片的显示方式,可以使用object-fit属性。例如,你可以设置object-fit: cover;来确保图片始终覆盖其容器的整个区域,同时保持宽高比,这可能会导致图片的某些部分被裁剪。

.myImg {  width: 100%;  height: 100%;  object-fit: cover;  
}

或者,使用object-fit: contain;来确保图片的完整显示,但可能会在容器内留有空白。


3. 使用javaScript来调整图片尺寸:

用于某些特定场景

虽然大多数情况下CSS足以处理图片尺寸问题,但在某些复杂的场景中,你可能需要使用JavaScript来动态调整图片的大小。这通常涉及到读取图片的原始尺寸,然后计算其应该缩放到的尺寸以适应容器。


4. 调整HTML和CSS结构:
从根源解决问题,但这个比较麻烦

确保img标签被放置在一个适当尺寸的容器中,并且该容器具有正确的CSS样式来控制其大小。如果容器本身的大小不正确,那么即使你调整了图片的大小,它也可能看起来不合适。


5. 使用响应式设计:

比较复杂,但适配度比前面的都高

对于需要在不同屏幕尺寸和设备上正确显示的图片,使用响应式设计技术是非常重要的。这通常涉及到使用媒体查询(media queries)来根据视口(viewport)的大小调整图片和容器的尺寸。

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

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

相关文章

MySQL建表以及excel内容导入

最近自学MySQL的使用,需要将整理好的excel数据导入数据库中,记录一下数据导入流程。 --建立数据库 create table SP_sjk ( --增加列 id NUMBER(20), mc VARCHAR2(300) ) /*表空间储存参数配置。一个数据库从逻辑上来说是由一个或多个表空间所组成&#…

CSS3DRenderer, CSS3DObject, OrthographicCamera API 结合使用案例

CSS3DRenderer, CSS3DObject, OrthographicCamera API 结合使用案例 <!DOCTYPE html> <html><head><title>three.js css3d - orthographic</title><meta charset"utf-8"><meta name"viewport" content"widthd…

【ArcGISPro】道路数据下载并使用

下载 下载链接: Geofabrik 下载服务器 这些数据通常 每天更新。 下载结果 arcmap用户下载工具 10.2:http://www.arcgis.com/home/item.html?id=16970017f81349548d0a9eead0ebba39 10.3:

力扣题目训练(20)

2024年2月13日力扣题目训练 2024年2月13日力扣题目训练594. 最长和谐子序列598. 区间加法 II599. 两个列表的最小索引总和284. 窥视迭代器287. 寻找重复数135. 分发糖果 2024年2月13日力扣题目训练 2024年2月13日第二十天编程训练&#xff0c;今天主要是进行一些题训练&#x…

UE5数字孪生系列笔记(二)

智慧城市数字孪生系统 制作流云动画效果 首先添加一个图像在需要添加流云效果的位置 添加动画效果让其旋转 这个动画效果是程序开始就要进行的&#xff0c;所以要在EventConstruct中就可以启动这个动画效果 添加一个一样的图像在这里&#xff0c;效果是从此处进行放大消散 添…

C语言---指针的两个运算符:点和箭头

目录 点&#xff08;.&#xff09;运算符箭头&#xff08;->&#xff09;运算符需要注意实际例子 C语言中的指针是一种特殊的变量&#xff0c;它存储了一个内存地址。点&#xff08;.&#xff09;和箭头&#xff08;->&#xff09;是用于访问结构体和联合体成员的运算符。…

promise和await/async区别?

Promise 是 JavaScript 中用于处理异步操作的对象&#xff0c;它代表一个异步操作的最终完成或失败&#xff0c;以及其结果值。而 async/await 是 ES8&#xff08;ECMAScript 2017&#xff09;引入的一种处理异步操作的方法&#xff0c;基于 Promise 实现的语法糖&#xff0c;使…

运行gazebo机器人模型没有cmd_vel话题

运行赵虚左教程代码出现上诉问题 roslaunch urdf02_gazebo demo03_env.launch 原因&#xff1a;缺少某个包 在工作空间catkin_make编译发现报错 解决&#xff1a; sudo apt-get install ros-noetic-gazebo-ros-pkgs ros-noetic-gazebo-ros-control 下载后再次运行launch文件…

Codeforces Round 931(div2)||ABC

A-Too Min Too Max 题意 对一个数组&#xff0c;找到索引 ( i , j , k , l ) (i,j,k,l) (i,j,k,l)使得 ∣ a i − a j ∣ ∣ a j − a k ∣ ∣ a k − a l ∣ ∣ a l − a i ∣ |a_i-a_j||a_j-a_k||a_k-a_l||a_l-a_i| ∣ai​−aj​∣∣aj​−ak​∣∣ak​−al​∣∣al​−…

60种常用可视化图表的使用场景——(下)

文章目录 31、径向柱图 32、热图 33、散点图 34、气泡图 35、气泡地形图 36、地区分布图 37、点示地图 38、连接地图 39、流向地图 40、甘特图 41、箱形图 42、子弹图 43、蜡烛图 44、跨度图 45、卡吉图 46、美国线 47、弦图 48、非彩带弦图 49、树形图 50、流程图 51、脑力激荡…

Volume优化

低效volume影响 解算时间&#xff1b;存储大小&#xff1b;渲染时间&#xff1b;服务器I/O&#xff1b;迭代次数&#xff1b;影响队友&#xff1b; 降低volume数据 体素精度分辨率&#xff1b;根据离相机的远近设置不同的分辨率&#xff1b;数据位数&#xff1b;删除不需要的数…

python知识点总结(一)

这里写目录标题 一、什么是WSGI,uwsgi,uWSGI1、WSGI2、uWSGI3、uwsgi 二、python中为什么没有函数重载&#xff1f;三、Python中如何跨模块共享全局变量?四、内存泄露是什么?如何避免?五、谈谈lambda函数作用?六、写一个函数实现字符串反转&#xff0c;尽可能写出你知道的所…

react中使用腾讯地图

腾讯文档 申请好对应key 配置限额 https://lbs.qq.com/service/webService/webServiceGuide/webServiceQuota 代码 用到的服务端接口 1.逆地址解析 2.关键词输入提示 import React, { Component } from react; import styles from ./map.less import { Form, Row, Col, I…

Go 语言中的 Cond 机制详解

概述 在并发编程中&#xff0c;条件同步是一个常见的需求。Go 语言提供了 sync.Cond 类型来满足这一需求。sync.Cond 基于互斥锁&#xff08;sync.Mutex&#xff09;提供了条件变量的同步机制&#xff0c;允许一组 goroutine 在满足某个条件时进行阻塞等待&#xff0c;或者在条…

python接口自动化之DDT数据驱动测试

一、简单介绍 DDT&#xff08;Date Driver Test&#xff09;&#xff0c;所谓数据驱动测试&#xff0c;简单来说就是由数据的改变从而驱动自动化测试的执行&#xff0c;最终引起测试结果的改变。通过使用数据驱动测试的方法&#xff0c;可以在需要验证多组数据测试场景中&…

C#混淆心得

C#混淆心得 近期遇到混淆C#代码的需求&#xff0c;在网上找了很多办法&#xff0c;在此记录一下。 混淆的本质就是让代码变丑&#xff0c;让别人看不懂。 为什么要混淆&#xff1a; 1.保护核心代码 可以在一定程度上避免别人偷代码&#xff0c;从而保护重要的部分&#xf…

postman---postman参数化

我们在做接口测试的过程中&#xff0c;都会遇到同一个接口不同的数据&#xff0c;每次去一个个填写数据就太麻烦了&#xff0c;今天我们一起学习下如何通过postman进行参数化 一、参数化 参数化就是1个接口请求不同的数据&#xff0c;我们可以通过把请求的数据放入到一个文件…

滑动窗口和螺旋矩阵

209. 长度最小的子数组 题目 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续 子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度**。**如果不存在符合条件的子数组&#xff0c;返回…

LInux 进程替换(理解系统调用)

目录 一、替换原理 二、替换函数 1、exec函数 2、命名理解 3、返回值 4、使用execl/lp、execv/vp 5、执行自定义命令 Makefile编译多个文件 命令行程序mycmd.c 传入自己的可执行文件 7、子进程都继承父进程环境变量 8、execle/ve修改子进程环境变量 9、exece函数为…

编写测试用例的方法,这个是真的很好用

大家测试过程中经常用的等价类划分、边界值分析、场景法等&#xff0c;并不能覆盖所有的需求&#xff0c;我们之前讲过很少用到的因果图法&#xff0c;下面就来讲另一种不经常用到但又非常重要的测试用例编写方法——测试大纲法。 测试大纲法适用于有多个窗口&#xff0c;每个…