真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何提高CSS效率-創(chuàng)新互聯(lián)

小編給大家分享一下如何提高CSS效率,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司是一家專業(yè)提供道縣企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、HTML5建站、小程序制作等業(yè)務(wù)。10年已為道縣眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。


相對(duì)單位
聰明又有前瞻頭腦的開發(fā)者們已經(jīng)使用相對(duì)單位了——如em或者百分比——所以,開發(fā)者們了解這個(gè)問題:往往因?yàn)樵氐睦^承性而需要使用計(jì)算器作為輔助工具來(lái)計(jì)算大小。例如,現(xiàn)在普遍的做法是給頁(yè)面的字體設(shè)置全局尺寸,然后用相對(duì)單位來(lái)定義頁(yè)面中其它的元素。CSS大概會(huì)這樣寫:



代碼如下:


html { font-size: 10px; } p { font-size: 1.4em; }



這樣寫是沒問題,直到有個(gè)子元素需要設(shè)置一個(gè)不同的字體大小,比如,在這樣的標(biāo)簽當(dāng)中:
The cat sat on the mat.
如果你要設(shè)置span的字體大小為1.2em,你需要做什么?拿出計(jì)算器,算算1.2除以1.4是多少,結(jié)果如下:



代碼如下:


p span { font-size: 0.85714em; }



這個(gè)問題不局限于em。如果用百分比來(lái)創(chuàng)建響應(yīng)式的流式布局網(wǎng)站,而百分比是與容器相關(guān)的,所以,如果要定義一個(gè)元素為它的容器的40%,它的高是75%,寬則需要設(shè)置為53.33333%。
很明顯,這很不方便。

根相關(guān)的長(zhǎng)度單位
為了修復(fù)字體大小定義的問題,現(xiàn)在可以使用單位rem(root em)。rem同樣是相對(duì)單位,但是它所對(duì)應(yīng)的是固定的基本值,這個(gè)固定的基本值也就是文檔的根元素的字體大小(在HTML文件中,就是html元素)。假設(shè)和上個(gè)例子一樣,同樣設(shè)定10px的字體大小為根元素的大小,那么CSS這樣寫就OK了:



代碼如下:


p { font-size: 1.4rem; } p span { font-size: 1.2rem; }



這兩個(gè)CSS規(guī)則都是相對(duì)于根元素的字體大小,這樣的代碼更加優(yōu)雅和簡(jiǎn)便,特別是在設(shè)置簡(jiǎn)單的數(shù)值如10px或者12px的時(shí)候。這樣和使用px值很相似,不同點(diǎn)在于rem是可擴(kuò)展的。
在整篇文章介紹的特性中,rem特性相對(duì)來(lái)說是兼容性比較好,高級(jí)瀏覽器都能支持,包括IE9在內(nèi),除了Opera Mobile。

窗口相關(guān)的長(zhǎng)度單位
覺得rem單位很酷吧,如果還有另外一組單位能解決百分比的問題,那就更酷了。它和rem的道理相似,不同點(diǎn)在于,它相對(duì)的不是文檔的根元素,而是相對(duì)于設(shè)備窗口本身的大小。
這兩個(gè)單位就是vh和vw,即是相對(duì)于窗口大小的高和寬。每個(gè)單位在前面加上數(shù)字,代表的是多少個(gè)百分比。



代碼如下:


div { height: 50vh; }



在上面的例子,高度被設(shè)定為窗口高度的一半。1vh相當(dāng)于一個(gè)百分比的窗口高度,所以50vh即是50%的窗口高度。
如果窗口大小變了,那么這個(gè)值也隨之改變。這相對(duì)百分比來(lái)說,好處是不需要擔(dān)心父容器,不管它的父容器如何,10vw的元素會(huì)一直是10%的窗口大小。
相應(yīng)地,有vmin單位,相當(dāng)于vh或者vw的最小值,最近還宣布有vmax單位會(huì)被加到規(guī)范文檔里面(雖然在這篇文章發(fā)布的時(shí)候還沒有)。
現(xiàn)在支持這個(gè)特性的有IE9+、Chrome和Safari 6。

運(yùn)算式的值
如果你在做響應(yīng)式的流式布局網(wǎng)站,經(jīng)常會(huì)遇到混合單位的問題——用百分比設(shè)置柵格,但是又用固定像素寬度設(shè)置margin。如:



代碼如下:


div { margin: 0 20px; width: 33%;}



如果布局只用到padding和border,你可以使用box-sizing來(lái)解決,但是對(duì)于margin就無(wú)能為力了。更好、更靈活的方法是使用calc()函數(shù),設(shè)置不同單位之間的數(shù)學(xué)方程式,如:



代碼如下:


div { margin: 0 20px; width: calc(33% - 40px);}



它不僅可以用來(lái)計(jì)算寬,還可以用來(lái)計(jì)算長(zhǎng)度——如果有必要,還可以在calc()里面再加calc()。
這個(gè)特性IE9+和Firefox都支持,F(xiàn)irefox需要加上 -moz- 前綴(在版本16或17可能不用加前綴),Chrome和Safari也支持,但需要加上 -webkit- 前綴。然而,移動(dòng)Webkit還不支持。

加載字體庫(kù)的部分字體
優(yōu)越的性能往往很重要,尤其是市場(chǎng)上各種各樣的移動(dòng)設(shè)備——導(dǎo)致連接速度的差異和不確定性——更加體現(xiàn)了這個(gè)重要性。其中一個(gè)加快頁(yè)面加載速度的方法,就是減少外部文件個(gè)數(shù),@font-face的一個(gè)新屬性u(píng)nicode-range就是為此而生。
這個(gè)屬性就是unicode-range(編碼范圍),代表的是編碼字體的參數(shù)范圍。在加載外部文件的時(shí)候,只有那些被使用的字體才會(huì)被加載,而不是整套字體庫(kù)。下面的代碼演示了如何從foo.ttf字體庫(kù)中僅加載三個(gè)字體:



代碼如下:


@font-face {font-family: foo;src: url('foo.ttf');unicode-range: U+31-33;}



這點(diǎn)對(duì)于使用字體圖標(biāo)的頁(yè)面尤其有用。我測(cè)試過,使用unicode-range,加載字體文件的時(shí)間平均減少了0.85秒,也不是小數(shù)目了。當(dāng)然,你可能不會(huì)這么想。
這個(gè)屬性,目前可以在IE9+、Webkit瀏覽器(如Chrome和Safari)中運(yùn)行。

新的偽類
單位和值都應(yīng)該好好利用,但是,讓我更興奮的是選擇器和偽類。完善的選擇器模式,即使只有少數(shù)瀏覽器支持,都讓我興奮不已。引用喬布斯的話:你要把柵欄的里面修得和外面一樣漂亮,即使別人看不到里面——因?yàn)槟阕约褐馈?br/>我第一次使用:nth-of-type()的時(shí)候,簡(jiǎn)直是一次突破,就像我沖出了思想的桎梏。好吧,我有些夸張了。但有些新的CSS偽類,確實(shí)值得狂熱一番。

否定偽類
你大概不知道 :not() 偽類的好,除非你親自實(shí)踐一番。帶有參數(shù)的 :not() 其實(shí)就是普通的選擇器——不是復(fù)合選擇器。一組元素加上選擇器 :not(),表示滿足這個(gè)參數(shù)的元素會(huì)被排除出去。聽起來(lái)有些復(fù)雜吧?但是實(shí)際上非常簡(jiǎn)單。
假設(shè):要對(duì)項(xiàng)目列表的奇數(shù)行進(jìn)行選擇,但是最后一行除外。如果是以前,需要這樣寫:



代碼如下:


li { color: #00F; } li:nth-child(odd) { color: #F00; } li:last-child { color: #00F; }



現(xiàn)在,通過設(shè)定:last-child作為否定偽類的參數(shù),就可以把最后一個(gè)元素排除,這樣少了一行代碼,從而更加的簡(jiǎn)潔和易維護(hù)。



代碼如下:


li { color: #00F; } li:nth-child(odd):not(:last-child) { color: #F00; }



否定偽類看起來(lái)并沒有什么驚人之處,你可以不用它,但是它還是挺實(shí)用的。我曾經(jīng)把它用在基于Webkit的項(xiàng)目當(dāng)中,優(yōu)勢(shì)還是挺明顯的。說實(shí)話,它是我最喜歡的偽類之一。
是的,我有最喜歡的偽類。
在本文提到的特性當(dāng)中,否定偽類是兼容性好的,它被IE9+和高級(jí)瀏覽器支持(不需要加瀏覽器產(chǎn)商前綴)。如果你熟悉jQuery,你可能習(xí)慣用它——版本1.0開始就有了,以及相似的not()方法。

“適用于”偽類
:matches() 偽類可以用普通的選擇器、復(fù)合選擇器、逗號(hào)隔開的列表或任何的選擇器組合作為參數(shù)。太棒了!但是,它能做什么?
:matches() 偽類最強(qiáng)大的地方就是聚合多行選擇器。例如,要選擇父容器里面其中幾個(gè)不同子容器里面的p元素,在這之前,代碼或許會(huì)寫成這樣:



代碼如下:


.home header p,.home footer p,.home aside p {color: #F00;}



有了:matches()偽類,就可以把共同點(diǎn)提取出來(lái),縮減代碼量。該例子里面,選擇器的共同點(diǎn)是以home為起點(diǎn)、以p為終點(diǎn),所以可以用:matches()把中間的所有元素集合起來(lái)。是不是有些困惑?看看代碼就明白了:



代碼如下:


.home :matches(header,footer,aside) p { color: #F00; }



這其實(shí)是CSS4的一部分(確切地說,是CSS選擇器第四等級(jí)),這份規(guī)范文檔還提到將會(huì)有類似的語(yǔ)法(以逗號(hào)隔開的復(fù)合選擇器)應(yīng)用于:not()偽類。興奮ing!
目前,:matches()可以在Chrome和Safari瀏覽器中運(yùn)行,但是要加上前綴-webkit-,F(xiàn)irefox也支持,但是要按照舊的寫法:any(),同時(shí)要加上-moz-前綴。


以上是“如何提高CSS效率”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


本文名稱:如何提高CSS效率-創(chuàng)新互聯(lián)
網(wǎng)站網(wǎng)址:http://weahome.cn/article/ccicss.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部