中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

如何提高CSS效率

發布時間:2021-10-14 09:55:40 來源:億速云 閱讀:147 作者:小新 欄目:移動開發

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


相對單位
聰明又有前瞻頭腦的開發者們已經使用相對單位了——如em或者百分比——所以,開發者們了解這個問題:往往因為元素的繼承性而需要使用計算器作為輔助工具來計算大小。例如,現在普遍的做法是給頁面的字體設置全局尺寸,然后用相對單位來定義頁面中其它的元素。CSS大概會這樣寫:

代碼如下:


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


這樣寫是沒問題,直到有個子元素需要設置一個不同的字體大小,比如,在這樣的標簽當中:
The cat sat on the <span>mat</span>.
如果你要設置span的字體大小為1.2em,你需要做什么?拿出計算器,算算1.2除以1.4是多少,結果如下:

代碼如下:


p span { font-size: 0.85714em; }


這個問題不局限于em。如果用百分比來創建響應式的流式布局網站,而百分比是與容器相關的,所以,如果要定義一個元素為它的容器的40%,它的高是75%,寬則需要設置為53.33333%。
很明顯,這很不方便。

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

代碼如下:


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


這兩個CSS規則都是相對于根元素的字體大小,這樣的代碼更加優雅和簡便,特別是在設置簡單的數值如10px或者12px的時候。這樣和使用px值很相似,不同點在于rem是可擴展的。
在整篇文章介紹的特性中,rem特性相對來說是兼容性比較好,高級瀏覽器都能支持,包括IE9在內,除了Opera Mobile。

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

代碼如下:


div { height: 50vh; }


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

運算式的值
如果你在做響應式的流式布局網站,經常會遇到混合單位的問題&mdash;&mdash;用百分比設置柵格,但是又用固定像素寬度設置margin。如:

代碼如下:


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


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

代碼如下:


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


它不僅可以用來計算寬,還可以用來計算長度&mdash;&mdash;如果有必要,還可以在calc()里面再加calc()。
這個特性IE9+和Firefox都支持,Firefox需要加上 -moz- 前綴(在版本16或17可能不用加前綴),Chrome和Safari也支持,但需要加上 -webkit- 前綴。然而,移動Webkit還不支持。

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

代碼如下:


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


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

新的偽類
單位和值都應該好好利用,但是,讓我更興奮的是選擇器和偽類。完善的選擇器模式,即使只有少數瀏覽器支持,都讓我興奮不已。引用喬布斯的話:你要把柵欄的里面修得和外面一樣漂亮,即使別人看不到里面&mdash;&mdash;因為你自己知道。
我第一次使用:nth-of-type()的時候,簡直是一次突破,就像我沖出了思想的桎梏。好吧,我有些夸張了。但有些新的CSS偽類,確實值得狂熱一番。

否定偽類
你大概不知道 :not() 偽類的好,除非你親自實踐一番。帶有參數的 :not() 其實就是普通的選擇器&mdash;&mdash;不是復合選擇器。一組元素加上選擇器 :not(),表示滿足這個參數的元素會被排除出去。聽起來有些復雜吧?但是實際上非常簡單。
假設:要對項目列表的奇數行進行選擇,但是最后一行除外。如果是以前,需要這樣寫:

代碼如下:


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


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

代碼如下:


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


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

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

代碼如下:


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


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

代碼如下:


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


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

以上是“如何提高CSS效率”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

css
AI

卓尼县| 朝阳区| 观塘区| 加查县| 丹巴县| 集安市| 化州市| 嘉定区| 榕江县| 静安区| 弥勒县| 正蓝旗| 彭泽县| 大埔县| 凭祥市| 琼结县| 万宁市| 仁化县| 柘荣县| 泰州市| 沁源县| 绥德县| 高密市| 南部县| 双鸭山市| 宁南县| 古浪县| 贵州省| 华容县| 辽宁省| 东乡族自治县| 崇左市| 清水河县| 吉隆县| 东台市| 岑巩县| 甘德县| 寿阳县| 海城市| 永春县| 原阳县|