溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形

發(fā)布時(shí)間:2021-03-16 15:36:05 來(lái)源:億速云 閱讀:191 作者:小新 欄目:web開發(fā)

這篇文章主要介紹CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

傳統(tǒng)方法正方形用固定的形式寫 直接長(zhǎng)=寬寫固定的值如下

.box{
		width: 200px;
		height: 200px;
		background: pink;
		color: #666;
	}

CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形

但是很多情況下,在移動(dòng)端的設(shè)計(jì)里,圖片的寬度隨著不同的移動(dòng)設(shè)備進(jìn)行改變的,這個(gè)時(shí)候就需要用到自適應(yīng)的正方形的實(shí)現(xiàn)。

下面介紹兩種比較簡(jiǎn)單的實(shí)現(xiàn)方法:

方法一:CSS3 vw 單位,vw是相對(duì)于視口的寬度。視口被均分為100單位的vw。1vw = 1% viewport width

.box{
		width: 20%;//width:20vw也可以
		height: 20vw;
		background: pink;
	}

方法二:設(shè)置盒子的padding-bottom樣式,讓盒子的padding-bottom和盒子的寬度一樣,同時(shí)設(shè)置heigh = 0px;

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<title></title>
		<link rel="stylesheet" href="">
	</head>
	<style>
                *{
            	    margin: 0;
	            padding: 0;
                }
		.box{
			width: 20%;
			/* 設(shè)置height為0 ,避免盒子被內(nèi)容撐開多余的高度 */
			height: 0px;
			/* 把盒子的高撐開,
			   和width設(shè)置同樣的固定的寬度或者百分比 ,
			   百分比相對(duì)的是父元素盒子的寬度 */
			padding-bottom: 20%;
			background: pink;
			color: #666;
		}
	</style>
	<body>
		<div class="box">	
	            <p>&nbsp;這是一個(gè)自適應(yīng)的正方形</p>
		</div>	
	</body>
</html>

CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形

要注意的是,如果這里沒有寫height:0px;當(dāng)盒子里面有內(nèi)容的時(shí)候,盒子會(huì)被內(nèi)容撐大

CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形      CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形

如果把padding-bottom改成padding-top會(huì)出現(xiàn)什么現(xiàn)象?

CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形       CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形

可以看出來(lái)在正方形中有內(nèi)容的時(shí)候,內(nèi)容會(huì)現(xiàn)實(shí)在正方形外面,這是因?yàn)槟J(rèn)文字是從左到右,從上到下的排列,所以paddin-top以后文字會(huì)在正方形外面,所以這里的paddin-bottom和padding-top并不能混用

另外因?yàn)楹凶釉O(shè)置了heigh:0px;導(dǎo)致該元素里面再有子元素的時(shí)候,就無(wú)法正常設(shè)置高度。所以我們需要用到position: absolute;使當(dāng)前內(nèi)容脫離文檔流,那么內(nèi)容的高度百分比參照的就是父級(jí)的寬度

*{
	margin: 0;
	padding: 0;
}
.box{
	width: 20%;
	/* 設(shè)置height為0 ,避免盒子被內(nèi)容撐開多余的高度 */
	height: 0px;
	/* 把盒子的高撐開,
	   和width設(shè)置同樣的固定的寬度或者百分比 ,
	   百分比相對(duì)的是父元素盒子的寬度 */
	padding-bottom: 20%;
	background: pink;
	color: #666;
	position: relative;
	overflow: hidden;
}
p{
	position: absolute;
	width: 100%;
	height: 100%;
	background: yellow;
}

CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形

這樣子盒子里面的內(nèi)容就把正方形占滿啦

以上是“CSS怎么實(shí)現(xiàn)自適應(yīng)的正方形”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI