国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

前端利器:SASS基礎(chǔ)與Compass入門

娣辯孩 / 3043人閱讀

摘要:在吸取了的一些特性基礎(chǔ)上,有了大幅改進(jìn),也就是現(xiàn)在的。嵌套極大程度上降低了選擇器名稱和屬性的重復(fù)書寫。選擇器嵌套選擇器嵌套是指從一個(gè)選擇器中嵌套子選擇器,來(lái)實(shí)現(xiàn)選擇器的繼承關(guān)系。也已經(jīng)成為的一個(gè)標(biāo)配組件。

  

SASS是Syntactically Awesome Stylesheete
Sass的縮寫,它是css的一個(gè)開發(fā)工具,提供了很多便利和簡(jiǎn)單的語(yǔ)法,讓css看起來(lái)更像是一門語(yǔ)言,這種特性也被稱為“css預(yù)編譯”。它的主要設(shè)計(jì)思想是讓我們可以按照編程的思路編寫自己的樣式,然后通過(guò)“編譯器”生成我們所需要的css文件。

當(dāng)然,SASS只是css預(yù)編譯工具中的一種,類似的工具還有Less、stylus等,SASS起初語(yǔ)法采用縮進(jìn)排列形式,但對(duì)于設(shè)計(jì)師來(lái)說(shuō)既不直觀還容易出現(xiàn)錯(cuò)誤。在吸取了Less的一些特性基礎(chǔ)上,SASS3.0有了大幅改進(jìn),也就是現(xiàn)在的SCSS。

為什么使用SASS/SCSS

易維護(hù),更方便的定制
對(duì)于一個(gè)大型或者稍微有規(guī)模的UI來(lái)說(shuō),如果需要替換下整體風(fēng)格,或者是某個(gè)字體的像素值,比如我們經(jīng)常會(huì)遇到panel,window以及portal共用一個(gè)背景色,這個(gè)時(shí)候按照常規(guī)的方式,我們需要一個(gè)個(gè)定位到元素使用的class,然后逐個(gè)替換,SASS提供了變量的方式,你可以把某個(gè)樣式作為一個(gè)變量,然后各個(gè)class引用這個(gè)變量即可,修改時(shí),我們只需修改對(duì)應(yīng)的變量。
對(duì)于編程人員的友好

對(duì)于一個(gè)沒(méi)有前端基礎(chǔ)的編程人員,寫css樣式是一件非常痛苦的事情,他們會(huì)感覺(jué)到各種約束,為什么我不能定一個(gè)變量來(lái)避免那些類似“變量”的重復(fù)書寫?為什么我不能繼承上個(gè)class的樣式定義?。。。SASS/SCSS正是幫編程人員解開了這些疑惑,讓css看起來(lái)更像是一門編程語(yǔ)言。

效率的提升
對(duì)于一個(gè)前端開發(fā)人員來(lái)說(shuō),我不熟悉編程,也不關(guān)注css是否具有的一些編程語(yǔ)言特性,但這不是你放棄他的理由,css3的發(fā)展,加之主流瀏覽器的兼容性不一,很多瀏覽器都有自己的兼容hack,很多時(shí)候我們需要針對(duì)不同的瀏覽器寫一堆的hack,這種浪費(fèi)時(shí)間的重復(fù)勞動(dòng)就交給SASS處理去吧!

安裝與使用

SASS最早來(lái)源于Haml項(xiàng)目,但這個(gè)工程飽受詬病,很多人認(rèn)為它使html失去語(yǔ)義化的特性,因此,并沒(méi)有廣泛的得到推廣,而源自于它的SASS受到一致的認(rèn)可,SASS基于Ruby編寫,也是Ruby On Rails的主力插件。盡管如此,你無(wú)需擔(dān)心自己沒(méi)有Ruby基礎(chǔ),你需要的只是一個(gè)Ruby環(huán)境(現(xiàn)在已經(jīng)有人把SASS移植到python編譯環(huán)境下了)。

Ruby的下載地址:https://www.ruby-lang.org/zhX31Xcn/ window下可以直接下載安裝包

安裝SASS,安裝完ruby之后,你就可以直接在命令行執(zhí)行下面的命令(注冊(cè)為環(huán)境變量):
>gem install sass

注:由于國(guó)內(nèi)網(wǎng)絡(luò)原因,可能會(huì)導(dǎo)致gem安裝插件時(shí)失敗,此時(shí)可以將gem源切換為淘寶的ruby鏡像站http://ruby.taobao.org/
3. 使用
SASS文件的后綴為.scss,可以使用下面的命令將scss文件編譯為最終使用的css文件:

sass demo.scss

或者指定css文件名

sass demo.scss product.css
基本語(yǔ)法 1. 變量

SASS支持變量的定義,你可以使用$來(lái)定義一個(gè)變量,這樣我們就可以把一些公用的樣式定義為一個(gè)變量,在使用時(shí)直接引用即可:

$white:#fff;
$font12:12px;
.menu{
    color: $white;
    font-size: $font12;
}

編譯后:

.menu {
  color: white;
  font-size: 12px;
}

2 .嵌套

SASS支持兩種嵌套方式:選擇器嵌套和屬性嵌套。嵌套極大程度上降低了選擇器名稱和屬性的重復(fù)書寫。

選擇器嵌套
選擇器嵌套是指從一個(gè)選擇器中嵌套子選擇器,來(lái)實(shí)現(xiàn)選擇器的繼承關(guān)系。

    .header{
       .logo{
           display: block;
           border: none;
       }
       ul li{
           line-break: normal;
       }
    }

編譯后:

.header .logo {
  display: block;
  border: none;
}
.header ul li {
  line-break: normal;
}

兩者對(duì)比不難發(fā)現(xiàn),省去了很大一部分的選擇器的層級(jí)聲明。
可以通過(guò)&來(lái)表示父元素選擇器,比如我們聲明一個(gè)a標(biāo)簽的樣式:

    a{
        text-decoration: none;
        &:hover{
            color: #007998;
        }
    }

編譯后:

a {
  text-decoration: none;
}
a:hover {
  color: #007998;
}

屬性嵌套
屬性嵌套,是指將帶有相同前綴單詞的屬性提出來(lái),作為一個(gè)公有的屬性,嵌套進(jìn)其他屬性,就像很多姓氏一樣的人,把這些人姓氏只記一次,后面跟上不同的名字。

    h3{
        font:{
            size:26px;
            weight:normal;
            family:arial
        }
    }

編譯后:

h3 {
  font-size: 26px;
  font-weight: normal;
  font-family: arial;
}

當(dāng)然實(shí)際情況font定義可能更簡(jiǎn)潔些,這里只是做一個(gè)示例。

3. 函數(shù)

SASS中,你可以對(duì)屬性值進(jìn)行簡(jiǎn)單的運(yùn)算, 比如:

$white:#fff;
$font12:12px;    
.newsize{
        font-size: $font12 + 2;
        color:$white - #007998;
    }

編譯后生成:

.newsize {
  font-size: 14px;
  color: #ff8667;
}

當(dāng)然除了最基本的加減乘除運(yùn)算函數(shù),SASS還提供了很多其他有趣的函數(shù),像我們最常用的顏色函數(shù)lighten(減淡)和darken(加深)。

.lgt{
    color: lighten($black,10%);
    background-color: darken($white,50%);
}

編譯后可以得到一個(gè)運(yùn)算好的顏色值:

.lgt {
  color: #1a1a1a;
  background-color: gray;
}

更多的函數(shù)信息,請(qǐng)查看SASS官方函數(shù)大全

4. 混合

SASS的混合是一個(gè)非常值得你去嘗試的特性,如果你對(duì)這個(gè)概念不太清楚,那么你可以認(rèn)為他就是一個(gè)模板的宏定義,而且這個(gè)宏還能接收參數(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為默認(rèn)參數(shù),可以通過(guò)傳遞參數(shù)來(lái)覆蓋默認(rèn)參數(shù),編譯后效果如下:

.circle {
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  border-radius: 10px;
}

除此之外,minxin還支持多個(gè)參數(shù),也支持類似于java中的String...類型的多個(gè)值的傳遞。

5. 繼承

既然SASS看起來(lái)像一門語(yǔ)言了,那么其他語(yǔ)言的一些基本特性,也應(yīng)該是其所具備的,SASS不孚眾望,具備了一個(gè)簡(jiǎn)單的繼承特性,使用這個(gè)特性需要關(guān)鍵字@extend。

.pclass{
  border: 4px solid #ff9aa9;
}
.subclass{
  @extend .pclass;
  border-width: 2px;
}

編譯后:

.pclass, .subclass {
  border: 4px solid #ff9aa9;
}

.subclass {
  border-width: 2px;
}
使用compass

介紹完SASS的一些基本入門知識(shí)點(diǎn)后,你是否有想嘗試下的沖動(dòng)呢?工欲善其事,必先利其器;這里簡(jiǎn)單介紹下一個(gè)開發(fā)中經(jīng)常使用的SASS工具compass,compass是SASS團(tuán)隊(duì)成員開發(fā)的,compass是對(duì)SASS的一個(gè)封裝,目的是為開發(fā)者提供一些豐富的mixin組件以及一些實(shí)用的工具模塊。compass也已經(jīng)成為ruby on rails的一個(gè)標(biāo)配組件。

安裝

安裝依然使用ruby gem安裝方式,參照前面安裝sass過(guò)程,gem命令如下:

gem install compass

現(xiàn)在安裝compass時(shí),一般都附帶安裝上了sass組件,也就是說(shuō)你可以跳過(guò)前面安裝sass的流程了。

getting start

工程的創(chuàng)建

compass create yourpj;

此時(shí)會(huì)在目錄下生成三個(gè)文件:

config.rb這是個(gè)配置文件,主要指定sass源文件地址,以及編譯后生成的css文件地址

sass存放sass源文件

stylesheets存放編譯后生成的css

已有工程的初始化
對(duì)于已經(jīng)創(chuàng)建好的工程,要想支持compass編譯,只需要初始化一下就可以(切換到指定目錄下):

 compass init

編譯
完成sass的開發(fā)后,只需要運(yùn)行下編譯命令:

compass compile

compile支持多種模式的編譯,詳細(xì)信息可通過(guò)compass compile -h查看。
每次編寫sass完成后,都需要手動(dòng)運(yùn)行下編譯命令,能不能自動(dòng)編譯呢?那當(dāng)然是可以的,只需要對(duì)當(dāng)前工程添加watch監(jiān)視,如下:

compass watch

組件模塊
前面我們提到compass提供了便捷的組件模塊,我們來(lái)一起看看有哪些常用的組件吧:

reset 瀏覽器樣式重置模塊,減少不同瀏覽器間的差異性

css3 css3命令模塊

layout 布局模塊

typography 版式模塊

utilities 工具類

reset使用:

@import "compass/reset";

這樣就會(huì)在css中生成重置樣式了,不用我們?cè)僮约憾x重置樣式了。

css3使用:

@import "compass/css3";

這是個(gè)絕對(duì)好用的特性,我們知道由于瀏覽器對(duì)css3支持的差異性,我們很多時(shí)候需要寫一堆針對(duì)不同瀏覽器前綴樣式,著實(shí)很煩人,css3命令模塊幫我們解決了這個(gè)問(wèn)題,我們只需include相應(yīng)樣式定義即可,compass會(huì)自動(dòng)為我們生成針對(duì)不同瀏覽器的樣式定義:

 @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;
  }

就寫到這吧,其他特性慢慢探討吧!

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/110885.html

相關(guān)文章

  • Gulp.js:比 Grunt 更簡(jiǎn)單的自動(dòng)化的項(xiàng)目構(gòu)建利器

    摘要:是一款基于任務(wù)的設(shè)計(jì)模式的自動(dòng)化工具,能給你的開發(fā)效率來(lái)一次飛躍。示例配置實(shí)現(xiàn)完整的自動(dòng)編譯并刷新網(wǎng)頁(yè)官方網(wǎng)站使用文檔插件列表 Gulp 是一款基于任務(wù)的設(shè)計(jì)模式的自動(dòng)化工具,能給你的開發(fā)效率來(lái)一次飛躍。 在很多場(chǎng)合都會(huì)聽到前端工和 node 程師推薦 Grunt 來(lái)實(shí)現(xiàn)項(xiàng)目的自動(dòng)化,自動(dòng)化可以自動(dòng)完成 javascript/coffee/sass/less 等文件的的測(cè)試、檢查、合并...

    Lsnsh 評(píng)論0 收藏0
  • Compass創(chuàng)建者Chris Eppstein:真正的CSS框架是如何工作的

    摘要:當(dāng)我的補(bǔ)丁被拒絕了之后,我想要指出一個(gè)方向真正的框架是如何工作的。發(fā)起這項(xiàng)捐助有我的個(gè)人原因在里面,我的父親在年被確診為患有一種罕見(jiàn)的成年人形式的線粒體疾病。正是一個(gè)經(jīng)歷了如此過(guò)程的產(chǎn)品。 非商業(yè)轉(zhuǎn)載請(qǐng)注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/article/120792 Chris Eppstein,Compass框架的創(chuàng)建...

    BigTomato 評(píng)論0 收藏0
  • [Sass]-Sass入門

    摘要:未編譯樣式多繼承鏈?zhǔn)嚼^承占位選擇器編譯后樣式中使用聲明混合,可以傳遞參數(shù),參數(shù)名以符號(hào)開始,多個(gè)參數(shù)以逗號(hào)分開,也可以給參數(shù)設(shè)置默認(rèn)值。 初識(shí)Sass SASS簡(jiǎn)介 sass是一種css預(yù)處理器,用專門的編程語(yǔ)言,進(jìn)行網(wǎng)頁(yè)樣式設(shè)計(jì),然后再編譯成正常的CSS文件。Sass是CSS3的擴(kuò)展,它增加了嵌套規(guī)則,變量,mixins,選擇器繼承等等。Sass生成格式良好的CSS,使樣式表更易于組...

    godiscoder 評(píng)論0 收藏0
  • 使用compass自動(dòng)合并css雪碧圖(css sprite)

    摘要:使用雪碧圖,能夠減少頁(yè)面的請(qǐng)求數(shù)降低圖片占用的字節(jié),以此來(lái)達(dá)到提升頁(yè)面訪問(wèn)速度的目的。也正是因?yàn)檫@一點(diǎn),導(dǎo)致很多開發(fā)者懶于使用雪碧圖。本文就介紹下怎樣使用來(lái)自動(dòng)合并雪碧圖。生成的每個(gè)雪碧圖默認(rèn)的規(guī)則是目錄名圖片名。 css雪碧圖又叫css精靈或css sprite,是一種背景圖片的拼合技術(shù)。使用css雪碧圖,能夠減少頁(yè)面的請(qǐng)求數(shù)、降低圖片占用的字節(jié),以此來(lái)達(dá)到提升頁(yè)面訪問(wèn)速度的目的。但...

    劉永祥 評(píng)論0 收藏0
  • [ 前端實(shí)習(xí)日記 ] 構(gòu)建靜態(tài)頁(yè)面基礎(chǔ)架構(gòu)

    以前我們敲靜態(tài)頁(yè)面都是寫好html,css, js,然后再去刷新瀏覽器,艾尼馬又不行,有重新寫過(guò)再刷新,一個(gè)頁(yè)面下來(lái)按chrl+r的次數(shù)可讓你的鍵盤多活好幾天,要不會(huì)刷新快捷按鈕那不得手殘了都。 后來(lái),grunt,gulp等工具應(yīng)運(yùn)而生,當(dāng)然它們不止這個(gè)功能,但卻很好地減輕了我們的負(fù)擔(dān)。這篇文章介紹一些如何使用這些工具使構(gòu)建頁(yè)面變得簡(jiǎn)單高效。這只是個(gè)人的目前在用的不成熟的方案,更專業(yè)的還請(qǐng)參考...

    lidashuang 評(píng)論0 收藏0

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

0條評(píng)論

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