傳統方法正方形用固定的形式寫 直接長=寬寫固定的值以下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
這樣子盒子裏面的內容就把正方形佔滿啦圖片