成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

愛上樸實的CSS細節(jié)

開發(fā) 前端
如果說這些特性是CSS華麗的一面,那我們來看看它樸實的一面:很不起眼的東西,如選擇器、單位、函數(shù)(方法)。我經(jīng)常說這是繁瑣的東西,但我意思是它們能干漂亮的活,這就是我要分享的。

未來的CSS太讓人興奮了:一方面,是全新的頁面布局方式;另一方面,是酷炫的濾鏡、顏色等視覺效果。這些CSS,受開發(fā)者追捧,被雜志和博客文章鋪天蓋地地介紹。

[[94083]]

如果說這些特性是CSS華麗的一面,那我們來看看它樸實的一面:很不起眼的東西,如選擇器、單位、函數(shù)(方法)。我經(jīng)常說這是繁瑣的東西,但我意思是它們能干漂亮的活,這就是我要分享的。

怎么說呢,讓我們看看這些效果***的樸實的CSS細節(jié)——這些細節(jié)遠遠沒有那些酷炫的CSS效果那么引人注目。它們有些已經(jīng)存在一段時間了,但值得我們更好地認識,而有些則剛剛面世。雖然不起眼,但是它們可以提高我們的工作效率——以謙虛的姿態(tài)。

相對單位

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

  1. html { font-size10px; } 

這樣寫是沒問題,直到有個子元素需要設置一個不同的字體大小,比如,在這樣的標簽當中:

  1. The cat sat on the <span>mat</span>. 

如果你要設置span的字體大小為1.2em,你需要做什么?拿出計算器,算算1.2除以1.4是多少,結(jié)果如下:

  1. p span { font-size0.85714em; } 

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

根相關(guān)的長度單位

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

  1. p { font-size1.4rem; } 

這兩個CSS規(guī)則都是相對于根元素的字體大小,這樣的代碼更加優(yōu)雅和簡便,特別是在設置簡單的數(shù)值如10px或者12px的時候。這樣和使用px值很相似,不同點在于rem是可擴展的。

在整篇文章介紹的特性中,rem特性相對來說是兼容性比較好,高級瀏覽器都能支持,包括IE9在內(nèi),除了Opera Mobile。

窗口相關(guān)的長度單位

覺得rem單位很酷吧,如果還有另外一組單位能解決百分比的問題,那就更酷了。它和rem的道理相似,不同點在于,它相對的不是文檔的根元素,而是相對于設備窗口本身的大小。

這兩個單位就是vh和vw,即是相對于窗口大小的高和寬。每個單位在前面加上數(shù)字,代表的是多少個百分比。

  1. div { height50vh; } 

在上面的例子,高度被設定為窗口高度的一半。1vh相當于一個百分比的窗口高度,所以50vh即是50%的窗口高度。

如果窗口大小變了,那么這個值也隨之改變。這相對百分比來說,好處是不需要擔心父容器,不管它的父容器如何,10vw的元素會一直是10%的窗口大小。

相應地,有vmin單位,相當于vh或者vw的最小值,最近還宣布有vmax單位會被加到規(guī)范文檔里面(雖然在這篇文章發(fā)布的時候還沒有)。

現(xiàn)在支持這個特性的有IE9+、Chrome和Safari 6。

運算式的值

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

  1. div { 

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

  1. div { 

它不僅可以用來計算寬,還可以用來計算長度——如果有必要,還可以在calc()里面再加calc()。

這個特性IE9+和Firefox都支持,F(xiàn)irefox需要加上 -moz- 前綴(在版本16或17可能不用加前綴),Chrome和Safari也支持,但需要加上 -webkit- 前綴。然而,移動Webkit還不支持。

加載字體庫的部分字體

優(yōu)越的性能往往很重要,尤其是市場上各種各樣的移動設備——導致連接速度的差異和不確定性——更加體現(xiàn)了這個重要性。其中一個加快頁面加載速度的方法,就是減少外部文件個數(shù),@font-face的一個新屬性unicode-range就是為此而生。

這個屬性就是unicode-range(編碼范圍),代表的是編碼字體的參數(shù)范圍。在加載外部文件的時候,只有那些被使用的字體才會被加載,而不是整套字體庫。下面的代碼演示了如何從foo.ttf字體庫中僅加載三個字體:

  1. @font-face { 

這點對于使用字體圖標的頁面尤其有用。我測試過,使用unicode-range,加載字體文件的時間平均減少了0.85秒,也不是小數(shù)目了。當然,你可能不會這么想。

這個屬性,目前可以在IE9+、Webkit瀏覽器(如Chrome和Safari)中運行。

新的偽類

單位和值都應該好好利用,但是,讓我更興奮的是選擇器和偽類。完善的選擇器模式,即使只有少數(shù)瀏覽器支持,都讓我興奮不已。引用喬布斯的話:你要把柵欄的里面修得和外面一樣漂亮,即使別人看不到里面——因為你自己知道。

我***次使用:nth-of-type()的時候,簡直是一次突破,就像我沖出了思想的桎梏。好吧,我有些夸張了。但有些新的CSS偽類,確實值得狂熱一番。

否定偽類

你大概不知道:not() 偽類的好,除非你親自實踐一番。帶有參數(shù)的:not() 其實就是普通的選擇器——不是復合選擇器。一組元素加上選擇器 :not(),表示滿足這個參數(shù)的元素會被排除出去。聽起來有些復雜吧?但是實際上非常簡單。

假設:要對項目列表的奇數(shù)行進行選擇,但是***一行除外。如果是以前,需要這樣寫:

  1. li { color#00F; } 

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

  1. li { color#00F; }  

否定偽類看起來并沒有什么驚人之處,你可以不用它,但是它還是挺實用的。我曾經(jīng)把它用在基于Webkit的項目當中,優(yōu)勢還是挺明顯的。說實話,它是我最喜歡的偽類之一。

是的,我有最喜歡的偽類。

在本文提到的特性當中,否定偽類是兼容性***的,它被IE9+和高級瀏覽器支持(不需要加瀏覽器產(chǎn)商前綴)。如果你熟悉jQuery,你可能習慣用它——版本1.0開始就有了,以及相似的not()方法。

“適用于”偽類

:matches()偽類可以用普通的選擇器、復合選擇器、逗號隔開的列表或任何的選擇器組合作為參數(shù)。太棒了!但是,它能做什么?

:matches()偽類***大的地方就是聚合多行選擇器。例如,要選擇父容器里面其中幾個不同子容器里面的p元素,在這之前,代碼或許會寫成這樣:

  1. .home header p, 

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

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

這其實是CSS4的一部分(確切地說,是CSS選擇器第四等級),這份規(guī)范文檔還提到將會有類似的語法(以逗號隔開的復合選擇器)應用于:not()偽類。興奮ing!

目前,:matches()可以在Chrome和Safari瀏覽器中運行,但是要加上前綴-webkit-,F(xiàn)irefox也支持,但是要按照舊的寫法:any(),同時要加上-moz-前綴。

你愛上這些樸實的CSS細節(jié)了嗎?

這篇文章講到的特性,最贊的一點是它們解決了現(xiàn)實的問題,從瑣碎而繁復的選擇器到建立響應式網(wǎng)站的新挑戰(zhàn)。實際上,我期待每一個特性被使用到最普通的項目當中。

新特性如濾鏡可能很直觀很華麗,但是我更愿意發(fā)現(xiàn)隱藏在深處的實用小技巧。

在積極探索的過程中,每一個特性可以讓你的職業(yè)生涯更順利——想到這里,就不會覺得繁瑣了。

原文鏈接:http://www.w3cfuns.com/thread-5594394-1-1.html

【編輯推薦】

  1. 你用的到的精美jQuery&CSS3效果
  2. 創(chuàng)建CSS3漂亮的動畫菜單
  3. 如何才能編寫出兼容各瀏覽器的CSS
  4. CSS3繪畫:一個安卓機器人!
  5. 精品 jQuery Ajax 分頁插件和教程
責任編輯:張偉 來源: w3cfuns
相關(guān)推薦

2010-08-27 09:37:44

DIV CSS

2013-01-17 14:49:20

創(chuàng)業(yè)

2014-11-13 10:22:18

Multi-cloud亞馬遜Web服務云數(shù)據(jù)庫

2020-05-13 13:15:05

systemdLinux腳本

2017-10-10 13:58:38

前端CSS濾鏡技巧

2019-11-07 09:34:43

Python語言Java

2020-11-30 07:00:49

Redis交流面試

2012-03-16 15:35:21

.netJava

2012-02-28 15:07:19

CSS3

2021-02-28 08:34:14

CSS outline-off負值技巧

2019-11-12 16:44:50

Go語言泛函編程設計

2010-09-06 10:15:13

UI設計MeeGo

2009-03-11 11:39:54

CSSJavascriptSEO

2013-04-19 09:50:51

編程編程語言編程經(jīng)驗

2020-04-27 21:31:28

智慧城市物聯(lián)網(wǎng)IOT

2021-01-04 13:40:59

Git開源工具

2017-07-21 10:30:01

Linux故障解決思路

2009-07-10 17:15:13

Javascript

2015-03-09 09:25:04

2010-05-25 13:22:43

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 免费成人国产 | 国产一级片免费视频 | 欧美在线一区二区三区四区 | 二区在线视频 | 毛片av免费在线观看 | 免费在线观看一区二区 | 亚洲精品无 | 自拍偷拍精品 | 天天躁日日躁狠狠躁2018小说 | 欧美视频日韩 | 欧美激情在线精品一区二区三区 | 伊人久久免费 | 日本欧美大片 | 亚洲一区二区三区视频在线 | 久久久久久亚洲 | 一区二区高清不卡 | 国产激情免费视频 | 免费在线a视频 | 国产91在线 | 亚洲 | 青青久久 | 91麻豆精品一区二区三区 | 国产精品美女视频 | 99久久免费精品视频 | 超碰av在线| 亚洲网站在线观看 | 男人av网| 久久精品这里精品 | 欧美精品在欧美一区二区少妇 | 狠狠干夜夜草 | 台湾a级理论片在线观看 | 成人自拍av | 国产91久久精品一区二区 | 免费黄色片在线观看 | 欧美精品一区二区三区四区五区 | 久久精品一区二区三区四区 | 日韩精品一区二区三区在线播放 | 久久久.com | 一区二区三区四区不卡 | 国产精品美女久久久久久免费 | 久久成人国产 | 日韩在线精品视频 |