设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间06 现在时间06 缓存数据 做一个积极向上的人,读温柔的句子,见阳光的人,眼里全是温柔和笑意。

做一个积极向上的人,读温柔的句子,见阳光的人,眼里全是温柔和笑意。

查看: 1613|回复: 2

CSS实现一个自适应的正方形的方法示例

[复制链接]

  离线 

TA的专栏

  • 打卡等级:热心大叔
  • 打卡总天数:205
  • 打卡月天数:0
  • 打卡总奖励:3314
  • 最近打卡:2023-08-27 04:20:45
等级头衔

等級:晓枫资讯-上等兵

在线时间
0 小时

积分成就
威望
0
贡献
371
主题
348
精华
0
金钱
4428
积分
746
注册时间
2022-12-24
最后登录
2025-3-13

发表于 2023-2-11 06:59:21 | 显示全部楼层 |阅读模式

传统方法正方形用固定的形式写 直接长=宽写固定的值如下

  1. .box{
  2. width: 200px;
  3. height: 200px;
  4. background: pink;
  5. color: #666;
  6. }
复制代码

080056oelinsz9lliiv7z9.png

但是很多情况下,在移动端的设计里,图片的宽度随着不同的移动设备进行改变的,这个时候就需要用到自适应的正方形的实现。

下面介绍两种比较简单的实现方法:

方法一:CSS3 vw 单位,vw是相对于视口的宽度。视口被均分为100单位的vw。1vw = 1% viewport width

  1. .box{
  2. width: 20%;//width:20vw也可以
  3. height: 20vw;
  4. background: pink;
  5. }
复制代码

方法二:设置盒子的padding-bottom样式,让盒子的padding-bottom和盒子的宽度一样,同时设置heigh = 0px;

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <title></title>
  7. <link rel="stylesheet" href="">
  8. </head>
  9. <style>
  10. *{
  11. margin: 0;
  12. padding: 0;
  13. }
  14. .box{
  15. width: 20%;
  16. /* 设置height为0 ,避免盒子被内容撑开多余的高度 */
  17. height: 0px;
  18. /* 把盒子的高撑开,
  19. 和width设置同样的固定的宽度或者百分比 ,
  20. 百分比相对的是父元素盒子的宽度 */
  21. padding-bottom: 20%;
  22. background: pink;
  23. color: #666;
  24. }
  25. </style>
  26. <body>
  27. <div class="box">
  28. <p>&nbsp;这是一个自适应的正方形</p>
  29. </div>
  30. </body>
  31. </html>
复制代码

080056ho5575umbu39o54n.png

要注意的是,如果这里没有写height:0px;当盒子里面有内容的时候,盒子会被内容撑大

080057bivyms8pfp8jmir1.png
      
080057wvizpuo5d2o2zm6y.png

如果把padding-bottom改成padding-top会出现什么现象?

080057d8bvpttdttb5xp9p.png
       
080057rjz1p5pw7c9i1cl6.png

可以看出来在正方形中有内容的时候,内容会现实在正方形外面,这是因为默认文字是从左到右,从上到下的排列,所以paddin-top以后文字会在正方形外面,所以这里的paddin-bottom和padding-top并不能混用

另外因为盒子设置了heigh

  1. :
复制代码
0px;导致该元素里面再有子元素的时候,就无法正常设置高度。所以我们需要用到
  1. position: absolute;使当前内容脱离文档流,那么内容的高度百分比参照的就是父级的宽度
复制代码

  1. *{
  2. margin: 0;
  3. padding: 0;
  4. }
  5. .box{
  6. width: 20%;
  7. /* 设置height为0 ,避免盒子被内容撑开多余的高度 */
  8. height: 0px;
  9. /* 把盒子的高撑开,
  10. 和width设置同样的固定的宽度或者百分比 ,
  11. 百分比相对的是父元素盒子的宽度 */
  12. padding-bottom: 20%;
  13. background: pink;
  14. color: #666;
  15. position: relative;
  16. overflow: hidden;
  17. }
  18. p{
  19. position: absolute;
  20. width: 100%;
  21. height: 100%;
  22. background: yellow;
  23. }
复制代码

080058jkifb3pvtb96ta3c.png

这样子盒子里面的内容就把正方形占满啦

到此这篇关于CSS实现一个自适应的正方形的方法示例的文章就介绍到这了,更多相关CSS 自适应正方形内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章,希望大家以后多多支持晓枫资讯!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

  • 打卡等级:无名新人
  • 打卡总天数:1
  • 打卡月天数:0
  • 打卡总奖励:5
  • 最近打卡:2024-12-06 17:52:52
等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
17
积分
4
注册时间
2023-12-27
最后登录
2024-12-6

发表于 2024-1-23 01:56:40 | 显示全部楼层
路过,支持一下
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
22
积分
24
注册时间
2022-12-25
最后登录
2022-12-25

发表于 2025-4-10 20:56:39 | 显示全部楼层
顶顶更健康!!!
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1楼
2楼
3楼

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表