Sass之自定義函數(shù)

考慮到sass自定義函數(shù)用到地方比較多揭措,并且后續(xù)需要單獨(dú)拿出來和Mixin胆数、extend進(jìn)行比較市埋,所以將原本屬于上一篇《Sass函數(shù)功能匯總》的這部分知識(shí)黎泣,在這里另開篇幅了。

【Sass函數(shù)功能匯總】:http://www.reibang.com/p/ef2ca6fbf944

1. 創(chuàng)建和使用自定義函數(shù)

Sass和其他腳本語(yǔ)言有類似之處缤谎,可以利用變量來構(gòu)建自己的函數(shù)抒倚,這使Sass可以像寫JavaScript那樣擁有自己的邏輯。下面是Sass自定義函數(shù)的基本結(jié)構(gòu):

@function function-name($args) {
    @return value-to-be-returned;
}
body{
  font-size: function-name($args);
}
  • 創(chuàng)建自定義函數(shù)需要兩個(gè)Sass指令坷澡, @function和 @return托呕。前者創(chuàng)建函數(shù),后者表明了函數(shù)將返回的值
  • function-name代表函數(shù)名频敛,在Sass中function-name和 function_name是相同的函數(shù)项郊,所以可使用破折號(hào)或下劃線調(diào)用函數(shù),無論命名時(shí)使用的是哪個(gè)斟赚。
  • 傳遞到函數(shù)中的參數(shù)$args是可選的着降,通常會(huì)使用傳遞過去的參數(shù)進(jìn)行運(yùn)算,也可能是一些所有函數(shù)都可以訪問的全局變量拗军。
//SCSS
@function column-width($col, $total) {
  @return percentage($col/$total);
}
.col-3 {
  width: column-width(3, 8);
}
.col-5 {
  width: column-width(5, 8);
}
//CSS
.col-3 {  width: 37.5%; }
.col-5 {  width: 62.5%; }

2. 關(guān)鍵字參數(shù)

傳參的時(shí)候有時(shí)候會(huì)不知道每個(gè)參數(shù)是什么意思任洞,參數(shù)之間是一個(gè)什么樣的順序蓄喇。為了解決這個(gè)問題,Sass允許通過語(yǔ)法$name: value的形式指定每個(gè)參數(shù)的值交掏。這種形式的傳參妆偏,參數(shù)順序就不必再在乎了,只需要保證沒有漏掉參數(shù)即可:

//SCSS
@function column-width($col, $total) {
  @return percentage($col/$total);
}
.col-3 {
  width: column-width($col:3, $total:8);
}
.col-5 {
  width: column-width($total:5,$col:8);
}
//CSS
.col-3 {  width: 37.5%; }
.col-5 {  width: 160%; }

3. 默認(rèn)參數(shù)

為了在使用函數(shù)是不必傳入所有的參數(shù)盅弛,我們可以給參數(shù)指定一個(gè)默認(rèn)值钱骂。參數(shù)默認(rèn)值使用$name: default-value的聲明形式,默認(rèn)值可以是任何有效的css屬性值挪鹏,甚至是其他參數(shù)的引用罐柳。

//SCSS
@function column-width($col:3, $total:8) {
  @return percentage($col/$total);
}
.col-3 {
  width: column-width($col:2, $total:4);
}
.col-5 {
  width: column-width();
}
//CSS
.col-3 {  width: 50%; }
.col-5 {  width: 37.5%; }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市狰住,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌齿梁,老刑警劉巖催植,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異勺择,居然都是意外死亡创南,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門省核,熙熙樓的掌柜王于貴愁眉苦臉地迎上來稿辙,“玉大人,你說我怎么就攤上這事气忠×诖ⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵旧噪,是天一觀的道長(zhǎng)吨娜。 經(jīng)常有香客問我,道長(zhǎng)淘钟,這世上最難降的妖魔是什么宦赠? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮米母,結(jié)果婚禮上勾扭,老公的妹妹穿的比我還像新娘。我一直安慰自己铁瞒,他們只是感情好妙色,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著精拟,像睡著了一般燎斩。 火紅的嫁衣襯著肌膚如雪虱歪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天栅表,我揣著相機(jī)與錄音笋鄙,去河邊找鬼。 笑死怪瓶,一個(gè)胖子當(dāng)著我的面吹牛萧落,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播洗贰,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼找岖,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了敛滋?” 一聲冷哼從身側(cè)響起许布,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎绎晃,沒想到半個(gè)月后蜜唾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡庶艾,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年袁余,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片咱揍。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡颖榜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出煤裙,到底是詐尸還是另有隱情掩完,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布积暖,位于F島的核電站藤为,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏夺刑。R本人自食惡果不足惜缅疟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望遍愿。 院中可真熱鬧存淫,春花似錦、人聲如沸沼填。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)坞笙。三九已至岩饼,卻和暖如春荚虚,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背籍茧。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工版述, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人寞冯。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓渴析,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親吮龄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子俭茧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)漓帚,斷路器母债,智...
    卡卡羅2017閱讀 134,707評(píng)論 18 139
  • 第2章 基本語(yǔ)法 2.1 概述 基本句法和變量 語(yǔ)句 JavaScript程序的執(zhí)行單位為行(line),也就是一...
    悟名先生閱讀 4,151評(píng)論 0 13
  • Lua 5.1 參考手冊(cè) by Roberto Ierusalimschy, Luiz Henrique de F...
    蘇黎九歌閱讀 13,836評(píng)論 0 38
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 29,417評(píng)論 8 265
  • 椰風(fēng)海韻蕩漾過唐宋詩(shī)明清畫 漁歌船帆飄灑在朝霞中夕陽(yáng)下 魂?duì)科抢@ 夢(mèng)里出發(fā) 我來到美麗富饒的三沙 永興島拜訪將軍林...
    珠江潮平閱讀 489評(píng)論 40 46