传统方法正方形用固定的形式写 直接长=宽写固定的值以下html
可是不少状况下,在移动端的设计里,图片的宽度随着不一样的移动设备进行改变的,这个时候就须要用到自适应的正方形的实现。post
下面介绍两种比较简单的实现方法:ui
方法一:CSS3 vw 单位,vw是相对于视口的宽度。视口被均分为100单位的vw。1vw = 1% viewport widthspa
方法二:设置盒子的padding-bottom样式,让盒子的padding-bottom和盒子的宽度同样,同时设置heigh = 0px;设计
要注意的是,若是这里没有写height:0px;当盒子里面有内容的时候,盒子会被内容撑大3d
若是把padding-bottom改为padding-top会出现什么现象?code
能够看出来在正方形中有内容的时候,内容会现实在正方形外面,这是由于默认文字是从左到右,从上到下的排列,因此paddin-top之后文字会在正方形外面,因此这里的paddin-bottom和padding-top并不能混用htm
另外由于盒子设置了heigh:
0px;致使该元素里面再有子元素的时候,就没法正常设置高度。因此咱们须要用到position: absolute;使当前内容脱离文档流,那么内容的高度百分比参照的就是父级的宽度
blog
这样子盒子里面的内容就把正方形占满啦图片