摘要:在吸取了的一些特性基礎上,有了大幅改進,也就是現(xiàn)在的。嵌套極大程度上降低了選擇器名稱和屬性的重復書寫。選擇器嵌套選擇器嵌套是指從一個選擇器中嵌套子選擇器,來實現(xiàn)選擇器的繼承關系。也已經(jīng)成為的一個標配組件。
SASS是Syntactically Awesome Stylesheete
Sass的縮寫,它是css的一個開發(fā)工具,提供了很多便利和簡單的語法,讓css看起來更像是一門語言,這種特性也被稱為“css預編譯”。它的主要設計思想是讓我們可以按照編程的思路編寫自己的樣式,然后通過“編譯器”生成我們所需要的css文件。
當然,SASS只是css預編譯工具中的一種,類似的工具還有Less、stylus等,SASS起初語法采用縮進排列形式,但對于設計師來說既不直觀還容易出現(xiàn)錯誤。在吸取了Less的一些特性基礎上,SASS3.0有了大幅改進,也就是現(xiàn)在的SCSS。
為什么使用SASS/SCSS易維護,更方便的定制
對于一個大型或者稍微有規(guī)模的UI來說,如果需要替換下整體風格,或者是某個字體的像素值,比如我們經(jīng)常會遇到panel,window以及portal共用一個背景色,這個時候按照常規(guī)的方式,我們需要一個個定位到元素使用的class,然后逐個替換,SASS提供了變量的方式,你可以把某個樣式作為一個變量,然后各個class引用這個變量即可,修改時,我們只需修改對應的變量。
對于編程人員的友好
對于一個沒有前端基礎的編程人員,寫css樣式是一件非常痛苦的事情,他們會感覺到各種約束,為什么我不能定一個變量來避免那些類似“變量”的重復書寫?為什么我不能繼承上個class的樣式定義?。。。SASS/SCSS正是幫編程人員解開了這些疑惑,讓css看起來更像是一門編程語言。
效率的提升
對于一個前端開發(fā)人員來說,我不熟悉編程,也不關注css是否具有的一些編程語言特性,但這不是你放棄他的理由,css3的發(fā)展,加之主流瀏覽器的兼容性不一,很多瀏覽器都有自己的兼容hack,很多時候我們需要針對不同的瀏覽器寫一堆的hack,這種浪費時間的重復勞動就交給SASS處理去吧!
SASS最早來源于Haml項目,但這個工程飽受詬病,很多人認為它使html失去語義化的特性,因此,并沒有廣泛的得到推廣,而源自于它的SASS受到一致的認可,SASS基于Ruby編寫,也是Ruby On Rails的主力插件。盡管如此,你無需擔心自己沒有Ruby基礎,你需要的只是一個Ruby環(huán)境(現(xiàn)在已經(jīng)有人把SASS移植到python編譯環(huán)境下了)。
Ruby的下載地址:https://www.ruby-lang.org/zhX31Xcn/ window下可以直接下載安裝包
安裝SASS,安裝完ruby之后,你就可以直接在命令行執(zhí)行下面的命令(注冊為環(huán)境變量):
>gem install sass
注:由于國內網(wǎng)絡原因,可能會導致gem安裝插件時失敗,此時可以將gem源切換為淘寶的ruby鏡像站http://ruby.taobao.org/
3. 使用
SASS文件的后綴為.scss,可以使用下面的命令將scss文件編譯為最終使用的css文件:
sass demo.scss
或者指定css文件名
sass demo.scss product.css基本語法 1. 變量
SASS支持變量的定義,你可以使用$來定義一個變量,這樣我們就可以把一些公用的樣式定義為一個變量,在使用時直接引用即可:
$white:#fff; $font12:12px; .menu{ color: $white; font-size: $font12; }
編譯后:
.menu { color: white; font-size: 12px; }2 .嵌套
SASS支持兩種嵌套方式:選擇器嵌套和屬性嵌套。嵌套極大程度上降低了選擇器名稱和屬性的重復書寫。
選擇器嵌套
選擇器嵌套是指從一個選擇器中嵌套子選擇器,來實現(xiàn)選擇器的繼承關系。
.header{ .logo{ display: block; border: none; } ul li{ line-break: normal; } }
編譯后:
.header .logo { display: block; border: none; } .header ul li { line-break: normal; }
兩者對比不難發(fā)現(xiàn),省去了很大一部分的選擇器的層級聲明。
可以通過&來表示父元素選擇器,比如我們聲明一個a標簽的樣式:
a{ text-decoration: none; &:hover{ color: #007998; } }
編譯后:
a { text-decoration: none; } a:hover { color: #007998; }
屬性嵌套
屬性嵌套,是指將帶有相同前綴單詞的屬性提出來,作為一個公有的屬性,嵌套進其他屬性,就像很多姓氏一樣的人,把這些人姓氏只記一次,后面跟上不同的名字。
h3{ font:{ size:26px; weight:normal; family:arial } }
編譯后:
h3 { font-size: 26px; font-weight: normal; font-family: arial; }
當然實際情況font定義可能更簡潔些,這里只是做一個示例。
3. 函數(shù)SASS中,你可以對屬性值進行簡單的運算, 比如:
$white:#fff; $font12:12px; .newsize{ font-size: $font12 + 2; color:$white - #007998; }
編譯后生成:
.newsize { font-size: 14px; color: #ff8667; }
當然除了最基本的加減乘除運算函數(shù),SASS還提供了很多其他有趣的函數(shù),像我們最常用的顏色函數(shù)lighten(減淡)和darken(加深)。
.lgt{ color: lighten($black,10%); background-color: darken($white,50%); }
編譯后可以得到一個運算好的顏色值:
.lgt { color: #1a1a1a; background-color: gray; }
更多的函數(shù)信息,請查看SASS官方函數(shù)大全
4. 混合SASS的混合是一個非常值得你去嘗試的特性,如果你對這個概念不太清楚,那么你可以認為他就是一個模板的宏定義,而且這個宏還能接收參數(shù)。
@mixin box-shadow{ -webkit-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); -moz-box-shadow:inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); } .funny-box{ @include box-shadow; }
編譯后:
.funny-box { -webkit-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); -moz-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); }
帶參數(shù)的mixin:
@mixin border-radius($circle:50px){ -webkit-border-radius: $circle; -moz-border-radius: $circle; border-radius: $circle; } .circle{ @include border-radius(10px); }
$circle:50px為默認參數(shù),可以通過傳遞參數(shù)來覆蓋默認參數(shù),編譯后效果如下:
.circle { -webkit-border-radius: 10px; -moz-border-radius: 10px; border-radius: 10px; }
除此之外,minxin還支持多個參數(shù),也支持類似于java中的String...類型的多個值的傳遞。
5. 繼承既然SASS看起來像一門語言了,那么其他語言的一些基本特性,也應該是其所具備的,SASS不孚眾望,具備了一個簡單的繼承特性,使用這個特性需要關鍵字@extend。
.pclass{ border: 4px solid #ff9aa9; } .subclass{ @extend .pclass; border-width: 2px; }
編譯后:
.pclass, .subclass { border: 4px solid #ff9aa9; } .subclass { border-width: 2px; }使用compass
介紹完SASS的一些基本入門知識點后,你是否有想嘗試下的沖動呢?工欲善其事,必先利其器;這里簡單介紹下一個開發(fā)中經(jīng)常使用的SASS工具compass,compass是SASS團隊成員開發(fā)的,compass是對SASS的一個封裝,目的是為開發(fā)者提供一些豐富的mixin組件以及一些實用的工具模塊。compass也已經(jīng)成為ruby on rails的一個標配組件。
安裝安裝依然使用ruby gem安裝方式,參照前面安裝sass過程,gem命令如下:
gem install compass
現(xiàn)在安裝compass時,一般都附帶安裝上了sass組件,也就是說你可以跳過前面安裝sass的流程了。
getting start工程的創(chuàng)建
compass create yourpj;
此時會在目錄下生成三個文件:
config.rb這是個配置文件,主要指定sass源文件地址,以及編譯后生成的css文件地址
sass存放sass源文件
stylesheets存放編譯后生成的css
已有工程的初始化
對于已經(jīng)創(chuàng)建好的工程,要想支持compass編譯,只需要初始化一下就可以(切換到指定目錄下):
compass init
編譯
完成sass的開發(fā)后,只需要運行下編譯命令:
compass compile
compile支持多種模式的編譯,詳細信息可通過compass compile -h查看。
每次編寫sass完成后,都需要手動運行下編譯命令,能不能自動編譯呢?那當然是可以的,只需要對當前工程添加watch監(jiān)視,如下:
compass watch
組件模塊
前面我們提到compass提供了便捷的組件模塊,我們來一起看看有哪些常用的組件吧:
reset 瀏覽器樣式重置模塊,減少不同瀏覽器間的差異性
css3 css3命令模塊
layout 布局模塊
typography 版式模塊
utilities 工具類
reset使用:
@import "compass/reset";
這樣就會在css中生成重置樣式了,不用我們再自己定義重置樣式了。
css3使用:
@import "compass/css3";
這是個絕對好用的特性,我們知道由于瀏覽器對css3支持的差異性,我們很多時候需要寫一堆針對不同瀏覽器前綴樣式,著實很煩人,css3命令模塊幫我們解決了這個問題,我們只需include相應樣式定義即可,compass會自動為我們生成針對不同瀏覽器的樣式定義:
@import "compass/css3"; .circle { @include border-radius(5px); }
編譯后:
.circle { -moz-border-radius: 5px; -webkit-border-radius: 5px; -o-border-radius: 5px; -ms-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px; }
就寫到這吧,其他特性慢慢探討吧!
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/110885.html
摘要:是一款基于任務的設計模式的自動化工具,能給你的開發(fā)效率來一次飛躍。示例配置實現(xiàn)完整的自動編譯并刷新網(wǎng)頁官方網(wǎng)站使用文檔插件列表 Gulp 是一款基于任務的設計模式的自動化工具,能給你的開發(fā)效率來一次飛躍。 在很多場合都會聽到前端工和 node 程師推薦 Grunt 來實現(xiàn)項目的自動化,自動化可以自動完成 javascript/coffee/sass/less 等文件的的測試、檢查、合并...
摘要:當我的補丁被拒絕了之后,我想要指出一個方向真正的框架是如何工作的。發(fā)起這項捐助有我的個人原因在里面,我的父親在年被確診為患有一種罕見的成年人形式的線粒體疾病。正是一個經(jīng)歷了如此過程的產(chǎn)品。 非商業(yè)轉載請注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/article/120792 Chris Eppstein,Compass框架的創(chuàng)建...
摘要:未編譯樣式多繼承鏈式繼承占位選擇器編譯后樣式中使用聲明混合,可以傳遞參數(shù),參數(shù)名以符號開始,多個參數(shù)以逗號分開,也可以給參數(shù)設置默認值。 初識Sass SASS簡介 sass是一種css預處理器,用專門的編程語言,進行網(wǎng)頁樣式設計,然后再編譯成正常的CSS文件。Sass是CSS3的擴展,它增加了嵌套規(guī)則,變量,mixins,選擇器繼承等等。Sass生成格式良好的CSS,使樣式表更易于組...
摘要:使用雪碧圖,能夠減少頁面的請求數(shù)降低圖片占用的字節(jié),以此來達到提升頁面訪問速度的目的。也正是因為這一點,導致很多開發(fā)者懶于使用雪碧圖。本文就介紹下怎樣使用來自動合并雪碧圖。生成的每個雪碧圖默認的規(guī)則是目錄名圖片名。 css雪碧圖又叫css精靈或css sprite,是一種背景圖片的拼合技術。使用css雪碧圖,能夠減少頁面的請求數(shù)、降低圖片占用的字節(jié),以此來達到提升頁面訪問速度的目的。但...
以前我們敲靜態(tài)頁面都是寫好html,css, js,然后再去刷新瀏覽器,艾尼馬又不行,有重新寫過再刷新,一個頁面下來按chrl+r的次數(shù)可讓你的鍵盤多活好幾天,要不會刷新快捷按鈕那不得手殘了都。 后來,grunt,gulp等工具應運而生,當然它們不止這個功能,但卻很好地減輕了我們的負擔。這篇文章介紹一些如何使用這些工具使構建頁面變得簡單高效。這只是個人的目前在用的不成熟的方案,更專業(yè)的還請參考...
閱讀 3609·2021-09-02 15:11
閱讀 4522·2021-08-16 10:47
閱讀 1534·2019-08-29 18:35
閱讀 3015·2019-08-28 17:54
閱讀 2828·2019-08-26 11:37
閱讀 1477·2019-08-23 16:51
閱讀 1783·2019-08-23 14:36
閱讀 1786·2019-08-23 14:21