91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

CSS標準盒模型與浮動如何使用

發布時間:2022-08-03 16:54:54 來源:億速云 閱讀:154 作者:iii 欄目:web開發

這篇文章主要介紹“CSS標準盒模型與浮動如何使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“CSS標準盒模型與浮動如何使用”文章能幫助大家解決問題。

CSS標準盒模型與浮動如何使用

盒子模型

網頁布局的本質在于通過css布局將盒子模型擺放至合適的位置,再放入所需元素

1. 盒子模型(Box Model)

盒子模型有元素內容,內邊距,外邊距,邊框組成

標準盒子模型
CSS標準盒模型與浮動如何使用

2. 盒子邊框(border)
border : border-width || border-style || border-color
屬性作用
border-width定義邊框粗細,單位px
border-style定義邊框樣式
border-color定義邊框顏色

邊框樣式

  • none:無邊框

  • solid:實線邊框

  • dashed:虛線邊框

  • dotted:點線邊框

單獨設置一邊邊框的樣式

 border-top-style:樣式; border-top-width:寬度;border-top-color:顏色;border-top:寬度 樣式 顏色;

bottom,left,right以此類推

表格邊框

通過cellspacing=0單元格距離為0,但是兩個單元格之間的邊框重疊會是邊框變粗,通過css屬性

table{border-collapse:collapse}

使得邊框合并,不變粗

圓角邊框

border-radius:length;/*length 可以數字也可以百分比*/

正方形盒子變為圓形,矩形多用高度一半

3. 內邊距(padding)

邊框與內容之間的間距
CSS標準盒模型與浮動如何使用

屬性作用
padding-left左內邊距
padding-right右內邊距
padding-top上內邊距
padding-bottom下內邊距

也可以簡寫

值個數含義
1padding:上下左右內邊距
2padding:上下 左右
3padding:上 左右 下
4padding:上 右 下 左(順時針)

內盒尺寸計算

  • 寬度

    Element Height = content height + padding + border (Height為內容高度)

  • 高度

    Element Width = content width + padding + border (Width為內容寬度)

  • 盒子的實際的大小 = 內容的寬度和高度 + 內邊距 + 邊框

當未直接給出width時,padding不會撐開盒子,否則會

4. 外邊距(margin)

外邊距是控制盒子與盒子之間的距離

屬性作用
margin-left左外邊距
margin-right右外邊距
margin-top上外邊距
margin-bottom下外邊距
  • 同樣類似于padding有類似的寫法

塊級盒子水平居中

盒子必須指定寬度,然后左右外邊距設置為auto

.nav{width:960px;margin:0 auto;}

常見的寫法,以下下三種都可以。

  • margin-left: auto; margin-right: auto;

  • margin: auto;

  • margin: 0 auto;

文字居中與盒子居中的區別

  • 盒子內的文字水平居中是 text-align: center, 而且還可以讓 行內元素和行內塊居中對齊

  • 塊級盒子水平居中 左右margin 改為 auto

插入圖片與背景圖片區別

  • 插入圖片移動位置只能靠 padding與margin

  • 背景圖則使用background-position

清楚元素內外邊距

* {
	padding:0;
	margin:0;
}

外邊距合并

  • 當上下相鄰的兩個塊元素相遇時,如果上面的元素有下外邊距margin-bottom

  • 下面的元素有上外邊距margin-top,則他們之間的垂直間距不是margin-bottom與margin-top之和

  • 取兩個值中的較大者這種現象被稱為相鄰塊元素垂直外邊距的合并(也稱外邊距塌陷)。
    CSS標準盒模型與浮動如何使用

解決方案:盡量給只給一個盒子添加margin值

嵌套塊元素垂直外邊距的合并

對于父子塊元素,父元素會與子元素合并,父元素沒有上padding和邊框,合并時外邊距取較大值
CSS標準盒模型與浮動如何使用

解決方案:

  • 可以為父元素定義上邊框。

  • 可以為父元素定義上內邊距

  • 可以為父元素添加overflow:hidden。

區分出父子元素

盒子布局穩定性

width>padding>margin

穩定性依次減小,padding會撐開盒子,margin在合并時也會有問題

5.盒子陰影
box-shadow:水平陰影 垂直陰影 模糊距離(虛實)  陰影尺寸(影子大小)  陰影顏色  內/外陰影;/*單位px*/
描述
h-shadow必需,水平陰影,負值在左邊
v-shadow必需,垂直陰影,負值在下
blur可選,模糊距離
spread可選,陰影尺寸
color可選,陰影顏色
inset可選,內陰影

注意

水平垂直陰影必須,其余可以省略,外陰影(outset)默認不寫

p {
	box-shadow:0 15px 20px rgba(0,0,0,.5)
}

浮動

1. 浮動是什么

css布局的三種機制

1. 普通

  • 塊級元素獨占一行,由上到下排列

  • 行內元素從左到右依次排列,父元素換行

2. 浮動

使得盒子浮動起來。讓多個塊級盒子一行展示

3. 定位

將盒子定位于瀏覽器中的某一位置

2. 浮動使用

通過浮動可以使得多個p水平排列一行,且之間沒有空白縫隙,實現左右對齊,最早使用于圖片,實現文字環繞效果

選擇器 {float: 值;}
屬性值描述
none不浮動(默認)
left元素向左浮動
right元素向右浮動

注意

浮動托標使用浮動后,元素會脫離標準流,后續的標準流會移動至浮動盒子底下,浮動元素會“漂浮”

CSS標準盒模型與浮動如何使用

浮動會改變 元素display屬性,任何元素都可以浮動,浮動元素相互緊靠,父級寬度裝不下時,多出盒子調至下一行

浮動與標準流搭配

給浮動元素添加一個標準流父親,在子元素使用浮動,從而較少對其他標準流的影響

3. 浮動與其他盒子關系
  • 浮動元素與父盒子關系

子盒子會與父盒子對齊,但不會與邊框重疊,也不會超過父盒子的內邊距

  • 浮動元素與兄弟盒子關系

浮動元素只會影響當前以及后面的標準流盒子

如果一個盒子里面有多個子盒子,如果其中一個盒子浮動了,其他兄弟也應該浮動。防止引起問題

4.清除浮動

很多子元素浮動后,父元素很難直接給出高度,最后父級盒子高度為0,對于以后的標準流盒子會有影響,對于標準流,子盒子會撐開盒子,而浮動不會。

清除就是為了消除浮動布局對于后續排版影響,主要是解決父元素高度為0的問題

選擇器 {clear: 屬性值;}
屬性值描述
left不允許左側有浮動元素(消除左側浮動影響)
right不允許右側有浮動元素(消除右側浮動影響)
both同時清除左右浮動元素

額外標簽法

是W3C推薦的做法是通過在浮動元素末尾添加一個空的標簽例如 <p style=”clear:both”></p>,或則其他標簽br等亦可。
  • 優點: 通俗易懂,書寫方便

  • 缺點: 添加許多無意義的標簽,結構化較差。

父級添加overflow屬性

overflow : hidden|auto|scroll

缺點: 內容增多時候容易造成不會自動換行導致內容被隱藏掉,無法顯示需要溢出的元素。

使用after為元素清除浮動

:after方式是額外標簽升級方式

.clearfix:after{ 
	content:""; display:block;height: 0;clear:both; visibility: hidden;
}

.clearfix {*zoom: 1;}
  • 優點: 符合閉合浮動思想 結構語義化正確

  • 缺點: 由于IE6-7不支持:after,使用 zoom:1觸發 hasLayout。

雙偽元素

.clearfix:before,.clearfix:after { 
  content:"";
  display:table; 
}
.clearfix:after {
 clear:both;
}
.clearfix {
  *zoom:1;
}

關于“CSS標準盒模型與浮動如何使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI

沾益县| 宣恩县| 汉中市| 凌源市| 博爱县| 博白县| 巴南区| 郸城县| 霍林郭勒市| 裕民县| 五指山市| 怀集县| 甘南县| 东光县| 宁津县| 河津市| 华安县| 通道| 和龙市| 普宁市| 马关县| 凤山市| 富锦市| 广昌县| 松阳县| 揭东县| 齐齐哈尔市| 东平县| 胶南市| 扶余县| 松原市| 商南县| 万州区| 明光市| 英超| 荣昌县| 沾化县| 靖边县| 铜陵市| 阿勒泰市| 阳朔县|