bootstrap-sass研究---(1)變量

之前有個預備篇,如果css選擇器不是太了解的可以去看看。

先從github上clone下整個項目,方便研究。


首先打開stylesheets/bootstrap/_variable.scss這個文件,我們看看這個項目的基礎 。

一開始是一組顏色的設置,是針對整個項目的全局變量,首先是一組常用的顏色,這個沒什么特別的,但是我們注意到

$blue:                  #049cdb !default;  //!default代表什么呢?
$blueDark:              #0064cd !default;

我去查了文檔,文檔給出了很清晰的解釋,!default讓當前的變量擁有一個比較低的優先級,如果這個變量之前就定義過,那么就使用之前的定義。文檔中還特別提醒,null也會被當成沒有定義過。

順便一提!important,千萬別混起來哦。


$headingsFontFamily:  inherit !default; // empty to use BS default, $baseFontFamily

使用瀏覽器默認的樣式,之前在想是不是inherit多此一舉?因為css中父元素的樣式在大多數情況下是會自動覆蓋下來的,但是考慮到總有一些奇怪的情況,這是一個增加它比重(weight) 的一個很好的方式。當然inherit也不是能繼承每個樣式的,想了解的去查下文檔。


$tableBackground:       transparent !default; // overall background-color

transparent是初始值,何必再去定義一下 ? 下面的參考資料里2號來自stackoverflow,提到了這個屬性make-sense的情況:

  1. 不使用縮寫方式,直接定義background-color屬性
  2. 使用它來覆蓋其他的樣式

并且給出了一個例子

body.foo { background-color: blue; }
body.foo.bar { background-color: transparent; }

當然還有可讀性,防止瀏覽器bug等原因,作者究竟是基于哪種考慮,我還不知道啊。


當然我們也一定要熟悉sass所內建的一些方法

$btnBackgroundHighlight:            darken($white, 10%) !default;
$btnWarningBackground:              lighten($orange, 15%) !default;

這兩個是一伙的,加深和變淺。它們是用ruby實現的。

def darken(color, amount)
  _adjust(color, amount, :lightness, 0..100, :-, "%")
end

大家感興趣可以繼續挖掘。

$btnPrimaryBackgroundHighlight:     adjust-hue($btnPrimaryBackground, 20%) !default;

還有這個,文檔中的解釋是

Changes the hue of a color while retaining the lightness and saturation. Takes a color and a number of degrees (usually between -360deg and 360deg), and returns a color with the hue rotated by that value.

在維持飽和度和亮度的情況下改變一個顏色的色調(有點繞是吧?google一下會感覺好點)。你可以設定的值是-360~360度之間。這個例子里面用的是百分比。

還有percentage方法,是將數字轉換成百分比
$fluidGridColumnWidth: percentage($gridColumnWidth/$gridRowWidth) !default;

它的源代碼也挺易懂的

# File '/var/www/sass-pages/.sass/lib/sass/script/functions.rb', line 1158
def percentage(value)
  unless value.is_a?(Sass::Script::Number) && value.unitless?
    raise ArgumentError.new("#{value.inspect} is not a unitless number")
  end
  Sass::Script::Number.new(value.value * 100, ['%'])
end

差不多把基礎打好了,我們休息一下繼續研究吧!

參考資料:

  1. stackoverflow => !default means?
  2. stackoverflow => what does background: transparent url(); do?
  3. sass-documentation
  4. sitepoint
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,825評論 6 546
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,814評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,980評論 0 384
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 64,064評論 1 319
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,779評論 6 414
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,109評論 1 330
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,099評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,287評論 0 291
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,799評論 1 338
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,515評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,750評論 1 375
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,221評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,933評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,327評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,667評論 1 296
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,492評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,703評論 2 380

推薦閱讀更多精彩內容

  • 選擇qi:是表達式 標簽選擇器 類選擇器 屬性選擇器 繼承屬性: color,font,text-align,li...
    wzhiq896閱讀 1,787評論 0 2
  • 選擇qi:是表達式 標簽選擇器 類選擇器 屬性選擇器 繼承屬性: color,font,text-align,li...
    love2013閱讀 2,327評論 0 11
  • 基礎 聲明變量 普通變量 默認變量 變量覆蓋:只需要在默認變量之前重新聲明下變量即可 變量的調用 局部變量和全局變...
    Jill1231閱讀 1,306評論 0 1
  • 1.CSS簡介 Cascading Style Sheet 層疊樣式表 主要用來定義頁面中的表現,HTML 描述頁...
    hyt222閱讀 854評論 0 0
  • 本文簡單的介紹SASS預處理語言,更多的應用請參考官方文檔 一、什么是SASS 二、為什么使用SASS 三、安裝S...
    CharlesDarwin閱讀 457評論 0 0