【CSS】css 如何实现固定宽高比

news2024/9/20 16:34:55

今天和同事讨论这个问题,一时间还想不到了,于是学习了下,就顺便当个记录吧

要在CSS中实现固定宽高比,有两种主要的方法可以选择。一种是使用新的aspect-ratio属性,另一种是利用padding技巧。随着现代浏览器对aspect-ratio属性的广泛支持,直接使用该属性已成为实现固定宽高比的首选方法。

使用 aspect-ratio 属性

aspect-ratio属性允许你定义元素盒子的宽高比,即使父容器或视口大小发生变化,浏览器也会调整元素的尺寸以保持指定的宽高比。至少需要一个盒子的尺寸是自动的,才能让aspect-ratio生效。如果宽度和高度都不是自动尺寸,那么提供的宽高比就不会影响盒子的首选尺寸。

以下是一个使用aspect-ratio属性的示例,它创建了一个具有16:9宽高比的元素:

.aspect-ratio-16-9 {
  aspect-ratio: 16 / 9;
  width: 100%; /* 或者任何你想要的宽度 */
  background-color: lightblue;
}
<div class="aspect-ratio-16-9"></div>

使用 padding-top 百分比技巧

对于不支持aspect-ratio属性的旧浏览器,你还可以使用padding技巧来维持元素的宽高比。这种方法基于元素的宽度百分比和其顶部填充百分比之间的关系

在这里插入图片描述

以下是一个使用padding-top技巧的示例,它创建了一个宽高比为1:1的元素:

.aspect-ratio-1-1 {
  position: relative;
  width: 100%; /* 或者任何你想要的宽度 */
  padding-top: 100%; /* 高度等于宽度 */
  background-color: lightblue;
}
<div class="aspect-ratio-1-1"></div>

这种方法的一个缺点是它依赖于元素的宽度,因此如果元素的宽度改变,宽高比也会改变。但是,对于大多数响应式设计来说,这种方法仍然非常有用。

比如你想要创建一个宽高比为16:9的div,你可以通过设置padding-top的百分比值来实现。这个百分比值是基于div的宽度计算的,因此要得到16:9的宽高比,你需要将padding-top设置为9 / 16 * 100%,即56.25%。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .container {
        position: relative;
        width: 100%;
        padding-top: 56.25%;
        /* aspect-ratio: 16 / 9; */
        background-color: red;
      }

      .content {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        background-color: red;
        text-align: center;
        line-height: 200px; /* Adjust based on your needs */
        font-size: 24px;
        color: black;
      }
    </style>
  </head>
  <body>
    <div class="container">
      <div class="content">Content Here</div>
    </div>
  </body>
</html>

总结

总结起来,使用aspect-ratio属性是实现固定宽高比的现代方法,因为它直接控制元素的宽高比,不受元素宽度的影响。而padding-top技巧则是一种兼容性更好的解决方案,适用于那些不支持aspect-ratio属性的旧浏览器。

参考

aspect-ratio - CSS:层叠样式表 | MDN

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

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

相关文章

27、美国国家冰雪中心(NSIDC)海冰密集度月数据下载与处理

文章目录 一、前言二、数据下载三、使用Ponply查看数据结构四、代码一、前言 处理美国国家冰雪中心(NSIDC)的海冰密集度月度数据时,坐标转换是一个重要的步骤。NSIDC提供的数据通常采用极地球面坐标系,需要将其转换为常用的地理坐标系(如经纬度)以便进行分析和可视化。 坐…

【数据结构与算法】共享双向链表

共享双向链表 一.共享双向链表的引入二.共享双向链表的原理三.共享双向链表的结构四.共享双向链表的初始化五.共享双向链表插入六.共享链表遍历数据七.共享链表的销毁八.总结 一.共享双向链表的引入 当我们使用双向链表其数据域是固定的类型,如果我需要另外一种类型的话,就需要…

共聚ISC|赛宁网安即将亮相ISC.AI2024第十二届互联网安全大会

随着数字时代的飞速发展&#xff0c;网络安全和人工智能技术的融合已成为推动各行业数智化转型的关键。7月31日至8月1日&#xff0c;备受瞩目的ISC.AI 2024第十二届互联网安全大会将在北京国家会议中心隆重开幕。本届大会将全面聚焦于安全和人工智能两大核心领域&#xff0c;致…

深入探讨Facebook投放菲律宾slots游戏广告的优势

在深入探讨Facebook投放菲律宾游戏广告的优势时&#xff0c;我们不得不提及该平台在本地市场的深厚渗透力与高度互动性。菲律宾作为东南亚地区互联网用户增长最快的国家之一&#xff0c;Facebook不仅是人们日常社交的必备工具&#xff0c;更是信息获取与娱乐消费的重要渠道。因…

Animation Clips

动画剪辑是Unity用来表示对象运动姿态的基础资源&#xff0c;你可以从模型文件中导入动画剪辑&#xff0c;也可以在Unity内部创建简单的动画剪辑。 Import Animation From Model 在导入时只需要确保模型的Animation选项卡中的Import Animation是被激活的&#xff0c;对于没有动…

【Linux】Ubuntu解决Release 文件已经过期问题

​今天在执行update更新软件包时遇到了此问题&#xff1a;E: http://cn.archive.ubuntu.com/ubuntu/dists/jammy-updates/InRelease 的 Release 文件已经过期(已经过期了 247天 21小时 33分 15秒)。该仓库的更新将不会应用&#xff0c;如图 ​ 这个报错之前其实经常遇到&#x…

品酒师眼中的红酒定制:一场不同的味觉盛宴

在红酒的世界里&#xff0c;每一滴酒液都承载着丰富的情感和不同的韵味。当谈到红酒定制时&#xff0c;洒派红酒&#xff08;Bold & Generous&#xff09;无疑为品酒师们带来了一场味觉盛宴。今天&#xff0c;就让我们一起跟随品酒师的目光&#xff0c;探索红酒定制背后的魅…

【Unity渲染】GI

光照探针 光照探针就是在烘焙的时候会布局多个探测点&#xff0c;记录那个地方的光照信息&#xff0c;后面实时渲染动态物体会影响其渲染&#xff0c;动态物体会选择自己周围最近的探针进行影响 反射探针 反射探针就是记录周围环境&#xff0c;计算一个类似天空盒的图片&am…

AIGC-VDM -Video Diffusion Models论文解读

homepage&#xff1a;https://video-diffusion.github.io/ paper:https://arxiv.org/pdf/2204.03458 参考:https://zhuanlan.zhihu.com/p/585009571 视频生成方面的扩散模型 论文Video Diffusion Models精读&#xff0c;笔者会多多更新AIGC相关知识&#xff01;点个关注吧&…

简单高效的在线拾色器工具 - 为您的设计工作提供便利

你是否曾在寻找完美颜色时感到困扰&#xff1f;现在&#xff0c;有了这个简单而强大的在线拾色器工具&#xff0c;选择理想的颜色变得轻而易举&#xff01; 网址&#xff1a; https://potatoh5games.fun/tools/#ColorPickr 这款拾色器工具具有以下特点&#xff1a; 用户友好…

外卖项目day09---微信登录/HttpClient

这里是初学的文章&#xff0c;大家可以去看看 HttpClient初学-CSDN博客 下面是微信登录的流程 微信登录产品原型 UserController代码 RestController RequestMapping("/user/user") Api(tags "C端用户相关接口") Slf4j public class UserController {A…

web以及nginx

⼀、web基本概念和常识 Web&#xff1a;为⽤户提供的⼀种在互联⽹上浏览信息的服务&#xff0c;Web 服务是动态的、可交互的、跨平台的和图形化的。 Web 服务为⽤户提供各种互联⽹服务&#xff0c;这些服务包括信息浏览服务&#xff0c;以及各种交互式服务&#xff0c;包括聊天…

【Python数值分析】革命:引领【数学建模】新时代的插值与拟合前沿技术

目录 ​编辑 第一部分&#xff1a;插值的基本原理及应用 1. 插值的基本原理 1.1 插值多项式 1.2 拉格朗日插值 1.3 牛顿插值 1.4 样条插值 2. 插值的Python实现 2.1 使用 NumPy 进行插值 2.2 使用 SciPy 进行插值 2.2.1 一维插值 ​编辑 2.2.2 二维插值 3. 插值…

如何让网站实现https访问

要让网站实现HTTPS访问&#xff0c;主要需要完成以下几个步骤。这些步骤确保了网站与用户之间的数据传输安全&#xff0c;并提升了用户对网站的信任度。 1. 确定证书类型 首先&#xff0c;根据网站的需求和预算&#xff0c;选择合适的SSL证书类型。常见的SSL证书类型包括&…

黑马头条Day11- 实时计算热点文章、KafkaStream

一、今日内容 1. 定时计算与实时计算 2. 今日内容 KafkaStream 什么是流式计算KafkaStream概述KafkaStream入门案例SpringBoot集成KafkaStream 实时计算 用户行为发送消息KafkaStream聚合处理消息更新文章行为数量替换热点文章数据 二、实时流式计算 1. 概念 一般流式计…

Skim通过Apple Script为选中文本添加特定颜色的高亮

一、代码编写 Skim的Apple Script维基页面 使用Mac的Script Editor编写以下代码&#xff1a; tell application "Skim"activatetell document 1set theSel to (get selection)set theNote to make note with data theSel with properties {type:highlight note, co…

Swift学习入门,新手小白看过来

&#x1f604;作者简介&#xff1a; 小曾同学.com,一个致力于测试开发的博主⛽️&#xff0c;主要职责&#xff1a;测试开发、CI/CD 如果文章知识点有错误的地方&#xff0c;还请大家指正&#xff0c;让我们一起学习&#xff0c;一起进步。 &#x1f60a; 座右铭&#xff1a;不…

零代码拖拽,轻松搞定GIS场景编辑

在三维GIS领域&#xff0c;编辑场景和处理影像数据通常是一个复杂且费时的过程&#xff0c;但现在有了山海鲸可视化&#xff0c;这一切都变得简单有趣。这款免费可视化工具为您提供了零代码拖拽式编辑的体验&#xff0c;让您无需编程知识就能轻松创建和优化GIS场景。通过直观的…

STM32——GPIO(点亮LEDLED闪烁)

一、什么是GPIO&#xff1f; GPIO&#xff08;通用输入输出接口&#xff09;&#xff1a; 1.GPIO 功能概述 GPIO 是通用输入/输出&#xff08;General Purpose I/O&#xff09;的简称&#xff0c;既能当输入口使用&#xff0c;又能当输出口使用。端口&#xff0c;就是元器件…

记一次因为在html两个地方引入vue.js导致组件注入失败的问题

这个问题我遇到两次了&#xff0c;是在恼火&#xff0c;不对&#xff0c;三次了&#xff0c;我如果不做这个笔记&#xff0c;我确定我还会遇到第三次。 尾部这个去掉就行 因为头部有了 遇到这种bu g好恼火&#xff0c;解决了又怎么样呢&#xff1f;重蹈覆辙的滋味不好受