成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

SASS學(xué)習(xí)記錄

tylin / 1653人閱讀

摘要:前言很久沒有用文章記錄自己的學(xué)習(xí)歷程了,主要是因?yàn)閷?shí)在寫的不行,相比大牛寫的博客,我這只能算是東拼西湊或者說是讀書筆記。以前我只使用外部,現(xiàn)在的更加好用,所以在學(xué)習(xí)過程中記了一些筆記。在后面加一個(gè)感嘆號(hào),表示這是重要注釋。

前言

很久沒有用文章記錄自己的學(xué)習(xí)歷程了,主要是因?yàn)閷?shí)在寫的不行,相比大牛寫的博客,我這只能算是東拼西湊或者說是讀書筆記。但是今天還是拾起筆來了,雖然沒什么干貨,但是對(duì)自己而言,總結(jié)的過程可以加深對(duì)零碎知識(shí)的了解,將來自己如果忘記某些知識(shí),可以迅速查找并撿起來;如果以后忘了自己的當(dāng)初的目標(biāo),也能回頭看看自己曾經(jīng)做過的努力。

想起總結(jié)的另一個(gè)原因,就是自己在最近的實(shí)習(xí)中學(xué)到了很多東西,終于把自己看過的零碎知識(shí)用起來了。應(yīng)了那句話,“紙上得來終覺淺,絕知此事要躬行”。當(dāng)前參與的項(xiàng)目是一個(gè)基于React做的單頁應(yīng)用,技術(shù)棧采用React+Redux+Webpack,樣式部分采用SCSS書寫。以前我只使用外部CSS,現(xiàn)在的SCSS更加好用,所以在學(xué)習(xí)過程中記了一些筆記。SCSS和CSS基本沒什么區(qū)別,只是增加了一些編程方法,這些方法都很簡(jiǎn)單,用起來受益匪淺。SASS和SCSS區(qū)別不大,所以我在本文僅提及SCSS。

SASS簡(jiǎn)介

SASS(Sassy CSS)是一種CSS開發(fā)工具,提供了CSS的便利寫法,通過編譯生成最終的CSS文件(補(bǔ)充,SASS的預(yù)編譯就是針對(duì)下述語法的再排版,沒有任何額外的處理加工,我以前覺得會(huì)將沖突樣式覆蓋掉什么的,目前看來并沒有)。
SASS安裝:SASS是用Ruby寫的,但是語法上沒有聯(lián)系,僅僅是需要安裝Ruby而已,然后在Ruby中安裝SASS,在Ruby的命令行中輸入以下命令即可:
gem install sass

將SASS編譯為CSS很簡(jiǎn)單:

    sass  //將SASS轉(zhuǎn)化為CSS并顯示在命令行上,
    sass  //將SASS轉(zhuǎn)換為CSS并保存在fileName.css中。
    sass -watch : //監(jiān)聽目標(biāo)文件,一旦有變動(dòng)就自動(dòng)生成編譯后的版本。

SASS的編譯風(fēng)格有四種:
nested: 嵌套縮進(jìn)的CSS代碼,是默認(rèn)值;
expanded:沒有縮進(jìn)的、擴(kuò)展的CSS代碼;
compact: 簡(jiǎn)潔格式的CSS代碼;
compressed: 壓縮后的CSS代碼,也就是去掉注釋和空格。生產(chǎn)環(huán)境中,一般采用compressed風(fēng)格降低代碼體積。一個(gè)完整的sass轉(zhuǎn)換命令如下:

        sass --style compressed test.sass test.css
        //--style compressed表示編程風(fēng)格

SASS簡(jiǎn)單編程風(fēng)格

SASS的簡(jiǎn)單用法包含使用變量、選擇器嵌套以及加減乘除運(yùn)算,復(fù)雜用法包括extend實(shí)現(xiàn)樣式繼承、Mixin實(shí)現(xiàn)代碼塊、顏色函數(shù)、@import插入外部CSS或SCSS文件、@if/@while/@each/@function實(shí)現(xiàn)的函數(shù)功能。
1允許使用變量,變量以$開頭,定義方式類似于CSS。如果變量需要鑲嵌在字符串之中,就必須需要寫在#{}之中。變量使用場(chǎng)景是那些需要全局復(fù)用的值,例如字體樣式,定義完之后直接調(diào)用有利于保持較大型CSS文件中字體的一致性。

  $side : left;
  .rounded {
    border-#{$side}-radius: 5px;
  }

一個(gè)有意思的特點(diǎn)是變量定義具有類似作用域的特性,嵌套的內(nèi)部標(biāo)簽?zāi)苁褂猛獠繕?biāo)簽的變量,但是如果不存在嵌套關(guān)系或者在外部使用內(nèi)部定義的變量,會(huì)導(dǎo)致錯(cuò)誤:
1)不存在嵌套關(guān)系不能引用:

2) 外部定義內(nèi)部可以使用:

3) 內(nèi)部定義外部不能使用:

如果一個(gè)變量想在全局引用,可以通過!global關(guān)鍵字實(shí)現(xiàn)這一點(diǎn):

2允許使用加減乘除,最終結(jié)果會(huì)在編譯后的CSS文件中體現(xiàn)出來:

3 SASS允許選擇器嵌套,好處是避免了父級(jí)選擇器的重復(fù),復(fù)雜CSS樣式可以借助類似HTML式的嵌套結(jié)構(gòu)表示出來。比如,下面的CSS代碼:

      div h1 {
        color : red;
      }

可以寫成:

      div {
        hi {
          color:red;
        }
      }

屬性也可以嵌套,比如border-color屬性,可以寫成:

      p {
        border: {
          color: red;
        }
      }

注意,border后面必須加上冒號(hào)。
在嵌套的代碼塊內(nèi),可以使用&引用父元素。比如a:hover偽類,可以寫成:

&必須位于復(fù)合選擇符的起始位置,但是可以加后綴。如果父級(jí)不能添加后綴,SASS會(huì)拋出錯(cuò)誤。

#main {
  color: black;
  &-sidebar { border: 1px solid; }
}

嵌套式寫法對(duì)具有命名空間的CSS屬性可以進(jìn)一步簡(jiǎn)化,例如font-family, font-size, and font-weight可以寫成

.funky {
  font: {
    family: fantasy;
    size: 30em;
    weight: bold;
  }
}

4 SASS共有兩種注釋風(fēng)格。標(biāo)準(zhǔn)的CSS注釋 / comment / ,會(huì)保留到編譯后的文件。單行注釋 // comment,只保留在SASS源文件中,編譯后被省略。在/*后面加一個(gè)感嘆號(hào),表示這是"重要注釋"。即使是壓縮模式編譯,也會(huì)保留這行注釋,通??梢杂糜诼暶靼鏅?quán)信息。

SASS高級(jí)用法

1 實(shí)現(xiàn)繼承
SASS允許一個(gè)選擇器繼承另一個(gè)選擇器,實(shí)現(xiàn)繼承的關(guān)鍵字和ES6實(shí)現(xiàn)class繼承的關(guān)鍵字類似是extend,例如希望class2繼承class1,在class2的樣式聲明中加入 @extend .class1即可。

2 實(shí)現(xiàn)Mixin
Mixin類似于c語言的宏,也就是可以重用的代碼塊,使用@mixin命令可以定義一個(gè)代碼塊。使用@include命令調(diào)用這個(gè)minxin即可。

代碼塊中可以指定默認(rèn)參數(shù),調(diào)用時(shí)可以賦值:

一個(gè)更經(jīng)典的例子是加入瀏覽器前綴,用法如下:

3 顏色函數(shù)生成系列顏色。

    lighten(#cc3, 10%) // #d6d65c
  darken(#cc3, 10%) // #a3a329
  grayscale(#cc3) // #808080
    complement(#cc3) // #33c

4 插入文件
@import命令插入外部文件,sass的導(dǎo)入(@import)規(guī)則和CSS的有所不同,編譯時(shí)會(huì)將@import的scss文件合并進(jìn)來只生成一個(gè)CSS文件。但是如果你在sass文件中導(dǎo)入css文件如@import "reset.css",那效果跟普通CSS導(dǎo)入樣式文件一樣,導(dǎo)入的css文件不會(huì)合并到編譯后的文件中,而是以@import方式存在。
使用@import的一個(gè)好處是所有外部文件的引入僅需要一個(gè)HTTP請(qǐng)求,但是CSS中使用@import命令就會(huì)引入多個(gè)HTTP請(qǐng)求,就網(wǎng)頁優(yōu)化而言在SASS中使用@import更有優(yōu)勢(shì)。
所有的sass導(dǎo)入文件都可以忽略后綴名.scss,但是CSS導(dǎo)入文件不可以省略后綴名。一般來說基礎(chǔ)的文件命名方法以_開頭,如_mixin.scss。這種文件在導(dǎo)入的時(shí)候可以不寫下劃線,可寫成@import "mixin"。

5 條件語句
使用@if和$else表示判斷

  @if lightness($color) > 30% {
    background-color: #000;
  } @else {
    background-color: #fff;
  }

6 循環(huán)語句使用@for、@while和$each語句。

@for $i from 1 to 10 {
    .border-#{$i} {
      border: #{$i}px solid blue;
    }
}

$i: 6;
  @while $i > 0 {
    .item-#{$i} { width: 2em * $i; }
    $i: $i - 2;
}

@each $member in a, b, c, d {
    .#{$member} {
      background-image: url("/image/#{$member}.jpg");
    }
  }

7 自定義函數(shù)

可以看出循環(huán)以及函數(shù)的使用類似于JavaScript,只是需要在關(guān)鍵字前加上@字符。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/81622.html

相關(guān)文章

  • SASS學(xué)習(xí)記錄

    摘要:前言很久沒有用文章記錄自己的學(xué)習(xí)歷程了,主要是因?yàn)閷?shí)在寫的不行,相比大牛寫的博客,我這只能算是東拼西湊或者說是讀書筆記。以前我只使用外部,現(xiàn)在的更加好用,所以在學(xué)習(xí)過程中記了一些筆記。在后面加一個(gè)感嘆號(hào),表示這是重要注釋。 前言 很久沒有用文章記錄自己的學(xué)習(xí)歷程了,主要是因?yàn)閷?shí)在寫的不行,相比大牛寫的博客,我這只能算是東拼西湊或者說是讀書筆記。但是今天還是拾起筆來了,雖然沒什么干貨,但...

    HollisChuang 評(píng)論0 收藏0
  • sass學(xué)習(xí)記錄

    摘要:核心團(tuán)隊(duì)不懈努力,一直使其保持領(lǐng)先地位。自身選擇器編譯成自身選擇器屬性嵌套編譯為占位符從以后就可以定義占位選擇器。將局部變量轉(zhuǎn)換為全局變量可以添加聲明編譯為默認(rèn)變量的默認(rèn)變量?jī)H需要在值后面加上即可。 sass簡(jiǎn)介 SASS是一種CSS的開發(fā)工具,提供了許多便利的寫法,大大節(jié)省了設(shè)計(jì)者的時(shí)間,使得CSS的開發(fā),變得簡(jiǎn)單和可維護(hù)。世界上最成熟、最穩(wěn)定、最強(qiáng)大的專業(yè)級(jí)CSS擴(kuò)展語言! 兼容C...

    xuweijian 評(píng)論0 收藏0
  • gulp基本配置

    摘要:之前用到用具的時(shí)候會(huì)習(xí)慣把要點(diǎn)記錄在云筆記里面,時(shí)間一場(chǎng)自己發(fā)現(xiàn)下次用的時(shí)候那些要點(diǎn)并沒有多大的提示效果,有些還是要從新看配置真是慚愧。 之前用到用具的時(shí)候會(huì)習(xí)慣把要點(diǎn)記錄在云筆記里面,時(shí)間一場(chǎng)自己發(fā)現(xiàn)下次用的時(shí)候那些要點(diǎn)并沒有多大的提示效果,有些還是要從新看配置(真是慚愧)。這才生出寫一點(diǎn)文章記錄的想法,給需要的同學(xué)提供一點(diǎn)幫助,也給自己作為一個(gè)學(xué)習(xí)的筆記。 以下是用gulp對(duì)網(wǎng)站靜...

    tyheist 評(píng)論0 收藏0
  • webpack+react項(xiàng)目初體驗(yàn)——記錄我的webpack環(huán)境配置

    摘要:安裝寫在里安裝和配置和之前一樣用來處理文件相關(guān)的這個(gè)包括的就比較多,有,后面兩個(gè)是為了寫和服務(wù)。 這兩天學(xué)習(xí)了一些webpack的知識(shí),loaders+plugins真的很強(qiáng)大!不過配置起來也很復(fù)雜,看了一些文章,自己也寫了項(xiàng)目練手,寫下來加深自己的印象。 首先,非常非常推薦的幾篇文章,初學(xué)者一定要看!http://www.jianshu.com/p/42e1...(標(biāo)題一點(diǎn)也不夸張,...

    csRyan 評(píng)論0 收藏0
  • 初探react技術(shù)棧(一)

    摘要:相信用的同學(xué)也不少找到函數(shù)在其中中添加啟用編譯。。。react 最近已經(jīng)開始使用react技術(shù)棧了,從頭開始搭建項(xiàng)目,有必要的記錄一下配置的過程以及項(xiàng)目分層的思路,這次后臺(tái)項(xiàng)目采用的主要采用react-create-app腳手架以及Ant DesignUI 以及多語言react-intl create-react-app 這是官方維護(hù)的腳手架應(yīng)用 我們一般也采用這個(gè) $ npm or c...

    劉玉平 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<