摘要:默認(rèn)值,沒有定位,元素出現(xiàn)在正常的文檔流中。生成粘性定位的元素,容器的位置根據(jù)正常文檔流計(jì)算得出。和屬性的異同共同點(diǎn)對內(nèi)聯(lián)元素設(shè)置和屬性,可以讓元素脫離文檔流,并且可以設(shè)置其寬高。
position的值, relative和absolute分別是相對于誰進(jìn)行定位的?
<1>、relative:相對定位,相對于自己本身在正常文檔流中的位置進(jìn)行定位。
<2>、absolute:生成絕對定位,相對于最近一級定位不為static的父元素進(jìn)行定位。
<3>、fixed: 生成絕對定位,相對于瀏覽器窗口或者frame進(jìn)行定位。
<4>、static:默認(rèn)值,沒有定位,元素出現(xiàn)在正常的文檔流中。
<5>、sticky:生成粘性定位的元素,容器的位置根據(jù)正常文檔流計(jì)算得出。
共同點(diǎn):對內(nèi)聯(lián)元素設(shè)置float和absolute屬性,可以讓元素脫離文檔流,并且可以設(shè)置其寬高。
不同點(diǎn):float仍可占據(jù)位置,不會覆蓋在另一個(gè)BFC區(qū)域上,浮動的框可以向左或向右移動,直到它的外邊緣碰到包含框或另一個(gè)浮動框的邊框?yàn)橹?。absolute會覆蓋文檔流中的其他元素。
box-sizing屬性主要用來控制元素的盒模型的解析模式。默認(rèn)值是content-box;
<1>、content-box:讓元素維持W3C的標(biāo)準(zhǔn)盒模型。元素的寬度/高度由border+padding+content的寬度/高度決定,設(shè)置width/height屬性指的是content部分的寬/高。
<2>、border-box:讓元素維持IE傳統(tǒng)盒模型(IE6以下版本和IE6~7的怪異模式)。設(shè)置width/height屬性指的是border+padding+content的寬度/高度。
<3>、padding-box:設(shè)置width/height屬性指的是padding+content的寬度/高度。
CSS 選擇符有哪些?哪些屬性可以繼承?優(yōu)先級算法如何計(jì)算? CSS3新增偽類有那些?標(biāo)準(zhǔn)瀏覽器下,按照W3C規(guī)范對盒模型解析,一旦修改了元素的邊框或邊距,就會影響元素的盒子尺寸,就不得不重新計(jì)算元素的盒子尺寸,從而影響整個(gè)頁面的布局。
選擇符:
<1>、id選擇器(#myId);
<2>、類選擇器(.myClassName);
<3>、標(biāo)簽選擇器(div,p,h1);
<4>、相鄰選擇器(h1 + p);
<5>、子選擇器(ul > li);
<6>、后代選擇器(li a);
<7>、通配符選擇器(*);
<8>、屬性選擇器(button[disabled="true"]);
<9>、偽類選擇器(a:hover,li:nth-child);表示一種狀態(tài)
<10>、偽元素選擇器(li:before、:after,:first-letter,:first-line,:selecton);表示文檔某個(gè)部分的表現(xiàn)
優(yōu)先級:
!important > 行內(nèi)樣式(比重1000) > id(比重100) > class/屬性(比重10) > tag / 偽類(比重1);
偽類和偽元素區(qū)別:
1>、偽類:a:hover,li:nth-child;
2>、偽元素:li:before、:after,:first-letter,:first-line,:selecton;
偽元素和偽類都是選擇器的補(bǔ)充,偽類表示的是一種狀態(tài),偽元素表示文檔的某個(gè)確定部分的表現(xiàn)。
偽元素選擇器選擇出來的部分不再dom里,也不能對其綁定事件,但是如果對偽元素前面的選擇器定義的元素綁定了事件,偽元素同樣會生效。
新增偽類
1>、li:first-of-type:選擇屬于其父元素的首個(gè)
BFC定義:塊級格式化上下文,一個(gè)創(chuàng)建了新的BFC的盒子是獨(dú)立布局的,盒子里面的子元素的樣式不會影響到外面的元素。在同一個(gè)BFC中的兩個(gè)相鄰的塊級盒在垂直方向的margin會發(fā)生折疊。
BFC布局規(guī)則:
1>、內(nèi)部的box會在垂直方向,一個(gè)接一個(gè)的放置。
2>、box的垂直方向的距離有margin決定。屬于同一個(gè)BFC的兩個(gè)相鄰box的margin會發(fā)生重疊。
3>、每個(gè)元素的margin box的左邊,與包含塊border box的左邊相接觸(對于從左往右的格式化,否則相反),即使存在浮動也是如此,除非這個(gè)盒子創(chuàng)建一個(gè)新的塊級格式化上下文。
4>、BFC的區(qū)域不會與float box重疊。
5>、BFC就是頁面上的一個(gè)隔離的獨(dú)立容器,容器里面的子元素不會影響到外面的元素。反之也是如此。
6>、計(jì)算BFC的高度時(shí),浮動元素也參與計(jì)算。
哪些元素會產(chǎn)生BFC:
1>、根元素;
2>、float屬性不為none;
3>、position為absolute或fixed;
4>、display為inline-block,table-cell,table-caption,flex,inline-flex;
5>、overflow除了visible以外的值(hidden、auto、scroll);
6>、fieldset元素
運(yùn)用BFC:
1>、解決margin重疊問題:根據(jù)BFC布局原則2,在元素外側(cè)包裹一層容器,并觸發(fā)該容器生成一個(gè)BFC,那么兩個(gè)元素就不在同一個(gè)BFC,就不會發(fā)生margin重疊。
Haha
Hehe
2>、自適應(yīng)兩欄布局:
根據(jù)BFC布局規(guī)則第3條:即使存在浮動的元素aslide,但main的左邊依然會與包含塊的左邊相接觸。
解決:根據(jù)BFC布局規(guī)則第4條,我們可以通過通過觸發(fā)main生成BFC, 來實(shí)現(xiàn)自適應(yīng)兩欄布局。
.main { overflow: hidden; }
當(dāng)觸發(fā)main生成BFC后,這個(gè)新的BFC不會與浮動的aside重疊。因此會根據(jù)包含塊的寬度,和aside的寬度,自動變窄。效果如下:
3>、清除內(nèi)部浮動:
根據(jù)BFC布局規(guī)則第6條:計(jì)算BFC的高度時(shí),浮動元素也參與計(jì)算,為達(dá)到清除內(nèi)部浮動,我們可以觸發(fā)par生成BFC,那么par在計(jì)算高度時(shí),par內(nèi)部的浮動元素child也會參與計(jì)算。
.par { overflow: hidden; }解釋下浮動和它的工作原理?清除浮動的技巧:
原理:任何元素都可以被浮動,浮動元素脫離文檔流,浮動的框可以向左或向右移動,直到它的外邊緣碰到包含框或另一個(gè)浮動框的邊框?yàn)橹埂?br>浮動引起的問題:
1>、父元素的高度無法被撐開,影響與父元素同級的元素;
2>、與浮動元素同級的非浮動元素(內(nèi)聯(lián)元素)會跟隨其后;
3>、若非第一個(gè)元素浮動,則該元素之前的元素也需要浮動,否則會影響頁面顯示的結(jié)構(gòu);
清除浮動:
1>、使用空標(biāo)簽清除浮動:
這種方法是在所有浮動標(biāo)簽后面添加一個(gè)空標(biāo)簽
#parent:after{ content:"."; height:0; visibility:hidden; display:block; clear:both; }
3>、浮動外部元素;
4>、設(shè)置父元素overflow為hidden或者auto,觸發(fā)父元素BFC;
1>、png24位的圖片在ie6瀏覽器上出現(xiàn)背景,解決方案是做成png8,也可以引用一段腳本處理。
2>、瀏覽器默認(rèn)的margin和padding不同。解決方案:加一個(gè)全局的*{margin:0;padding:0}。
3>、ie6雙邊距bug(20px距離):塊屬性標(biāo)簽float后,又有橫行的margin情況下,在ie6顯示margin值比設(shè)置的大。解決方案:在float標(biāo)簽樣式控制中加入_display:inline;將其轉(zhuǎn)化為行內(nèi)屬性。(_這個(gè)符號只有ie6會識別)。
4>、漸進(jìn)識別方式,從總體中逐步排除局部:
首先,巧妙的使用“9”這一標(biāo)記,將IE瀏覽器從所有情況中分離出來。
接著,再次使用“+”將IE8和IE7、IE6分離開來,這樣IE8已經(jīng)獨(dú)立識別。
.bb{ background-color:#f1ee18;/*所有識別*/ .background-color:#00deff9; /*IE6、7、8識別*/ +background-color:#a200ff;/*IE6、7識別*/ _background-color:#1e0bd1;/*IE6識別*/ }
待續(xù)....2015.5.29
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/112048.html
摘要:特意對前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 特意對前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 本以為自己收藏的站點(diǎn)多,可以很快搞定,沒想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補(bǔ)充。有錯誤的地方,還請斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應(yīng)和斧正,會及時(shí)更新,平時(shí)業(yè)務(wù)工作時(shí)也會不定期更...
摘要:獲取的對象范圍方法獲取的是最終應(yīng)用在元素上的所有屬性對象即使沒有代碼,也會把默認(rèn)的祖宗八代都顯示出來而只能獲取元素屬性中的樣式。因此對于一個(gè)光禿禿的元素,方法返回對象中屬性值如果有就是據(jù)我測試不同環(huán)境結(jié)果可能有差異而就是。 花了很長時(shí)間整理的前端面試資源,喜歡請大家不要吝嗇star~ 別只收藏,點(diǎn)個(gè)贊,點(diǎn)個(gè)star再走哈~ 持續(xù)更新中……,可以關(guān)注下github 項(xiàng)目地址 https:...
摘要:前端面試每日題,以面試題來驅(qū)動學(xué)習(xí),每天進(jìn)步一點(diǎn)讓努力成為一種習(xí)慣,讓奮斗成為一種享受相信堅(jiān)持的力量項(xiàng)目地址前端面試每日推薦歡迎跟一起折騰前端,系統(tǒng)整理前端知識,目前正在折騰,打算打通算法與數(shù)據(jù)結(jié)構(gòu)的任督二脈。 《論語》,曾子曰:吾日三省吾身(我每天多次反省自己)。 前端面試每日3+1題,以面試題來驅(qū)動學(xué)習(xí),每天進(jìn)步一點(diǎn)! 讓努力成為一種習(xí)慣,讓奮斗成為一種享受!相信 堅(jiān)持 的力量...
摘要:前端面試每日題,以面試題來驅(qū)動學(xué)習(xí),每天進(jìn)步一點(diǎn)讓努力成為一種習(xí)慣,讓奮斗成為一種享受相信堅(jiān)持的力量項(xiàng)目地址前端面試每日推薦歡迎跟一起折騰前端,系統(tǒng)整理前端知識,目前正在折騰,打算打通算法與數(shù)據(jù)結(jié)構(gòu)的任督二脈。 《論語》,曾子曰:吾日三省吾身(我每天多次反省自己)。 前端面試每日3+1題,以面試題來驅(qū)動學(xué)習(xí),每天進(jìn)步一點(diǎn)! 讓努力成為一種習(xí)慣,讓奮斗成為一種享受!相信 堅(jiān)持 的力量...
摘要:畢業(yè)之后就在一直合肥小公司工作,沒有老司機(jī)沒有技術(shù)氛圍,在技術(shù)的道路上我只能獨(dú)自摸索。于是乎,我果斷辭職,在新年開工之際來到杭州,這里的互聯(lián)網(wǎng)公司應(yīng)該是合肥的幾十倍吧。。。。 畢業(yè)之后就在一直合肥小公司工作,沒有老司機(jī)、沒有技術(shù)氛圍,在技術(shù)的道路上我只能獨(dú)自摸索。老板也只會畫餅充饑,前途一片迷??床坏饺魏蜗MS谑呛?,我果斷辭職,在新年開工之際來到杭州,這里的互聯(lián)網(wǎng)公司應(yīng)該是合肥的幾十...
閱讀 1065·2021-10-11 10:59
閱讀 3614·2021-09-26 09:55
閱讀 907·2019-08-30 15:55
閱讀 2663·2019-08-30 15:44
閱讀 445·2019-08-30 14:06
閱讀 691·2019-08-30 11:26
閱讀 3349·2019-08-30 10:49
閱讀 2506·2019-08-29 12:53