postcss的理解

前言


最近在項(xiàng)目開發(fā)中聽同事提起postcss秃流,然后就去網(wǎng)上看了些關(guān)于這方面的文章赂蕴,看的也是眼花繚亂,什么讓css像js一樣操作舶胀,讓css更靈活之類的概说,所以通過這篇文章我也從學(xué)習(xí)的角度來理解postcss。

一嚣伐、什么是postcss糖赔?

postcss是一種插件系統(tǒng),是基于js插件去轉(zhuǎn)換css的一個工具轩端,是js可以操作的一種數(shù)據(jù)形式放典。通俗點(diǎn)說它就是一個平臺,就是通過這個平臺可以開發(fā)一些我們自己的插件來處理css。

安裝postcss

全局安裝??npm install -g postcss-cli

本地安裝??npm install postcss --save-dev

二奋构、postcss組成結(jié)構(gòu)

PostCSS 提供了一個解析器壳影,它能夠?qū)?CSS 解析成抽象語法樹(AST)。

官方給出的介紹:

1. CSS Parser? 解析器

2. CSS 節(jié)點(diǎn)數(shù) API

3. source map 生成器

4. 生成節(jié)點(diǎn)樹串


三弥臼、為什么要用postcss宴咧?

在我們實(shí)際開發(fā)中,經(jīng)常會有一些困擾径缅,比如項(xiàng)目過大掺栅,我們的樣式缺乏模塊化的概念,全局變量經(jīng)常被同名問題困擾纳猪,當(dāng)定義class類多的時候經(jīng)常不知起什么名字好氧卧。

這些年隨著sass、less等預(yù)處理器的流行兆旬,讓css寫起來輕松了很多假抄。

postcss同樣可以實(shí)現(xiàn)sass、less一樣的功能丽猬,雖然他們不是一樣的東西宿饱,但是可以實(shí)現(xiàn)一樣的效果,只是postcss是通過插件去實(shí)現(xiàn)的脚祟。

插件系統(tǒng)?

當(dāng)然谬以,它不只是為了像sass、less一樣由桌,不然還開發(fā)它做咩咧为黎,哈哈。

1. 它能夠?yàn)閏ss提供額外的功能行您;

2.? 通過在postcss這個平臺上铭乾,我們能夠開發(fā)一些插件,來處理我們的css娃循,比如:autoprefixer

3.? 能夠使用javaScript來開發(fā)插件炕檩,就是完全使用js編寫;

插件基于css代碼的AST(語法樹)所能進(jìn)行的操作是多種多樣的捌斧,比如可以支持變量和混入(mixin)笛质,增加瀏覽器相關(guān)的聲明前綴,或是把使用將來的css規(guī)范的樣式規(guī)則轉(zhuǎn)譯成當(dāng)前的css規(guī)范支持的格式捞蚂,它的強(qiáng)大之處就在于其不斷發(fā)展的插件體系妇押。

postcss的主要功能有兩個:第一個就是前面提到的把css解析成javaScript可以操作的AST,第二個就是調(diào)用插件來處理AST并得到結(jié)果姓迅。因此不能簡單的把postcss歸類成css預(yù)處理或者后處理工具敲霍。

postcss的使用

postcss一般不單獨(dú)使用俊马,而是與已有的構(gòu)建工具進(jìn)行集成。比如Webpack色冀、Grunt和Gulp都可以進(jìn)行集成潭袱。完成集成后,選擇滿足功能需求的postcss插件并進(jìn)行配置锋恬。

具體使用請參考postcss使用方法

本文是對自己學(xué)習(xí)的一個記錄,其中用了個別大神博客的話编丘,如有侵權(quán)与学,聯(lián)系必刪!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末嘉抓,一起剝皮案震驚了整個濱河市索守,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌抑片,老刑警劉巖卵佛,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異敞斋,居然都是意外死亡截汪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進(jìn)店門植捎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來衙解,“玉大人,你說我怎么就攤上這事焰枢◎韭停” “怎么了?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵济锄,是天一觀的道長暑椰。 經(jīng)常有香客問我,道長荐绝,這世上最難降的妖魔是什么一汽? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮很泊,結(jié)果婚禮上角虫,老公的妹妹穿的比我還像新娘。我一直安慰自己委造,他們只是感情好戳鹅,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著昏兆,像睡著了一般枫虏。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天隶债,我揣著相機(jī)與錄音腾它,去河邊找鬼。 笑死死讹,一個胖子當(dāng)著我的面吹牛瞒滴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赞警,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼妓忍,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了愧旦?” 一聲冷哼從身側(cè)響起世剖,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎笤虫,沒想到半個月后旁瘫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡琼蚯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年酬凳,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片凌停。...
    茶點(diǎn)故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡粱年,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出罚拟,到底是詐尸還是另有隱情台诗,我是刑警寧澤,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布赐俗,位于F島的核電站拉队,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏阻逮。R本人自食惡果不足惜粱快,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望叔扼。 院中可真熱鬧事哭,春花似錦、人聲如沸瓜富。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽与柑。三九已至谤辜,卻和暖如春蓄坏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背丑念。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工涡戳, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人脯倚。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓渔彰,卻偏偏與公主長得像,于是被迫代替她去往敵國和親推正。 傳聞我的和親對象是個殘疾皇子胳岂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標(biāo)準(zhǔn)舔稀。 注意:講述HT...
    kismetajun閱讀 27,476評論 1 45
  • ??無論是 WEB 設(shè)計師或者是前端開發(fā)者,都少不了會接觸CSS掌测。更多的時間我們是通過工具來實(shí)現(xiàn)CSS開發(fā)的内贮,這些...
    MonoDog閱讀 1,868評論 0 7
  • 1 Webpack 1.1 概念簡介 1.1.1 WebPack是什么 1、一個打包工具 2汞斧、一個模塊加載工具 3...
    Kevin_Junbaozi閱讀 6,659評論 0 16
  • 壹 這是老麥在中國生活的第三個年頭夜郁,三年來,他在這里收獲了愛情粘勒,事業(yè)竞端,友情,以及很多庙睡。 不算友善的調(diào)侃事富。他覺得他應(yīng)...
    萌芽論壇閱讀 324評論 0 1
  • 用鉛筆勾勒 你躺在我的秘密里 安靜的乖巧的 記錄著我曾經(jīng)的時光 用彩鉛上色 如果你用明媚形容我 我會送你一束薔薇花...
    守素閱讀 273評論 12 10