前言
完成《CSS核心技術(shù)與實(shí)戰(zhàn)》這本書(shū),已有一個(gè)多月了,而這篇文章原本是打算寫(xiě)在那本書(shū)里面的,但本章講解的內(nèi)容,畢竟屬于CSS未來(lái)的范疇,而這一切都還不能夠確定下來(lái),所以這一章沒(méi)有寫(xiě)進(jìn)去,但不管怎么說(shuō),多少了解一下還是有好處的,里面部分功能,有些瀏覽器已經(jīng)實(shí)現(xiàn)了。
如果你對(duì)CSS預(yù)處理器感興趣,那么本篇文章也許很適合你。
初學(xué)CSS預(yù)處理器,其實(shí)我是不太明白為什么需要用這種東西的,后來(lái)想明白一件事,一切都是為了可維護(hù)性。比如下面這幅圖
距離左邊有一點(diǎn)點(diǎn)間距,而其他元素設(shè)置的間距往往也是一樣的,但如果不使用預(yù)處理器,或許我們會(huì)這樣寫(xiě)
.box{ padding:12px; }.footer{ padding:12px; } ....{ padding:12px; }
但這種問(wèn)題是,如果需要更改所有間距,你不得不誒個(gè)去替換,這樣帶來(lái)了很多不必要的工作量,如果使用預(yù)處理器就好辦了,因?yàn)轭A(yù)處理器是允許你使用變量的,你可以像編程語(yǔ)言那樣,定義一個(gè)全局變量,在需要的地方,引用這個(gè)全局變量,更改的時(shí)候,只需要修改一處就好了,假設(shè)代碼如下:
var pad = 2px; .box{ padding:pad; } .footer{ padding:pad; }
也就是說(shuō)預(yù)處理器很大一部分就是為了解決可維護(hù)性,本章講解的是后處理器。
那么后處理器和預(yù)處理器有什么區(qū)別
你可以這樣理解,后處理器就好比動(dòng)態(tài)語(yǔ)言,而預(yù)處理器就好比靜態(tài)語(yǔ)言。預(yù)