传统方法正方形用固定的形式写 直接长= 宽 写固定的值如下
.box{
width: 200px;
h ei ght: 200px;
background: pink;
color: # 666;
}
但是很多情况下,在移动端的设计里,图片的宽度随着不同的移动设备进行 改变 的,这个时候就需要用到自适应的正方形的实现。
下面介绍两种比较 简单 的实现方法:
方法一: CSS3 vw 单位,vw是相对于视口的宽度。视口被均分为100单位的vw。1vw = 1% viewport width
.box{
width: 20%;//width:20vw也可以
height: 20vw;
background: pink;
}
方法二: 设置 盒子 的padding-bottom样式,让盒子的padding-bottom和盒子的宽度一样,同时设置heigh =&nbs p; 0px;
<!DOCTY PE ht ML >
<html>
<head>
< ;m eta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE= Edge ">
<t IT le></title>
<link rel="stylesheet" hr ef="">
</head>
<style>
*{
m arg in: 0;
padding: 0;
}
.box{
width: 20%;
/* 设置height为0 ,避免盒子被内容撑开多余的高度 */
height: 0px;
/* 把盒子的高撑开,
和width设置同样的固定的宽度 或者 百分比 ,
百分比相对的是父元素盒子的宽度 */
padding-bottom: 20%;
background: pink;
color: #666;
}
</style>
<body>
<div class="box">
<p>& am p;nbsp;这是一个自适应的正方形</p>
</div>
</body>
</html>
要注意的是,如果这里没有写height:0px;当盒子里面有内容的时候,盒子会被内容撑大
如果把padding-bottom改成padding -t op会出现什么现象?
可以看出来在正方形中有内容的时候,内容会现实在正方形外面,这是因为默认文字是从左到右,从上到下的排列,所以paddin-top以后文字会在正方形外面,所以这里的paddin-bottom和padding-top并不能混用
另外因为盒子设置了heigh : 0px;导致该元素里面再有子元素的时候,就无法 正常 设置高度。所以我们需要用到 position: absolute;使当前内容脱离文档流,那么内容的高度百分比参照的就是父级的宽度
*{
mar gin : 0;
padding: 0;
}
.box{
width: 20%;
/* 设置height为0 ,避免盒子被内容撑开多余的高度 */
height: 0px;
/* 把盒子的高撑开,
和width设置同样的固定的宽度或者百分比 ,
百分比相对的是父元素盒子的宽度 */
padding-bottom: 20%;
background: pink;
color: #666;
position: relative;
overflow: hidden;
}
p{
position: absolute;
width: 100%;
height: 100%;
background: yellow;
}
这样子盒子里面的内容就把正方形占满啦
到此这篇关于CSS实现一个自适应的正方形的方法示例的 文章 就介绍到这了,更多相关CSS 自适应正方形内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
总结
以上是 为你收集整理的 CSS实现一个自适应的正方形的方法示例 全部内容,希望文章能够帮你解决 CSS实现一个自适应的正方形的方法示例 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于CSS实现一个自适应的正方形的方法示例的详细内容...