sass學習筆記

来源:http://www.cnblogs.com/qzccl/archive/2016/05/29/5540536.html
-Advertisement-
Play Games

sass和scss的區別 sass是以嚴格的縮進式語法規則來書寫,不帶大括弧({})和分號(;),scss和css寫法比較相似 Sass的編譯的過程中,是不是支持“GBK”編碼的。所以在創建 Sass 文件時,就需要將文件編碼設置為“utf-8 sass覆蓋預設變數值是在他之前重新聲明變數值(!de ...


sass和scss的區別

sass是以嚴格的縮進式語法規則來書寫,不帶大括弧({})和分號(;),scss和css寫法比較相似

Sass的編譯的過程中,是不是支持“GBK”編碼的。所以在創建 Sass 文件時,就需要將文件編碼設置為“utf-8

sass覆蓋預設變數值是在他之前重新聲明變數值(!default)

混合巨集:@mixin font(當需要使用變數的時候用)

@include font

Sass 在調用相同的混合巨集時,並不能智能的將相同的樣式代碼塊合併在一起。這也是 Sass 的混合巨集最不足之處。

繼承和擴展:@extend .class;(不需要使用變數的時候用,但是聲明出來的基類,不管有沒有被調用,都會出現在css裡面)

@extend 調用的占位符,編譯出來的代碼會將相同的代碼合併在一起

占位符:%(不需要使用變數的時候用,但是聲明出來的基類,沒有被調用,都不會出現在css裡面)

%placeholder 聲明的代碼,如果不被 @extend 調用的話,不會產生任何代碼

插值:#{}

@each...in...語句

進行運算的時候,帶單位的話,單位要相同。但是進行乘法運算的時候,帶單位的話,兩個單位相同的話,會出現錯誤,只要其中一個帶值就可以了。進行除法運算的時候,“/”符號,如果有其他的運算符的話就會生效,如果沒有的話,要記得帶括弧,不然不會生效,另外,在 Sass 除法運算中,當用變數進行除法運算時,“/”符號也會自動被識別成除法。但在除法運算時,如果兩個值帶有相同的單位值時,除法運算之後會得到一個不帶單位的數值

值列表

(1)   nth函數(nth function) 可以直接訪問值列表中的某一項;

(2)   join函數(join function) 可以將多個值列表連結在一起;

(3)   append函數(append function) 可以在值列表中添加值; 

(4)   @each規則(@each rule) 則能夠給值列表中的每個項目添加樣式。

 

@for迴圈

@for $i from <start> through <end>

@for $i from <start> to <end>

$i 表示變數

start 表示起始值

end 表示結束值

這兩個的區別是關鍵字 through 表示包括 end 這個數,而 to 則不包括 end 這個數。

@while

直到遇到false才會停止迴圈

@while $types > 0 {

    .while-#{$types} {

        width : $type-width + $types;

    }

    $types : $types - 1;  // 自減

}

@each迴圈

@each $var in <list>

函數功能

(1) 字元串函數

(2) 數字函數

(3) 列表函數

(4) 顏色函數

(5) Introspection 函數

(6) 三元函數等

(1)    字元串函數:用來處理字元串的函數

      unquote($string):刪除字元串中的引號;只能刪除字元串最前和最後的引號(雙引號或單引號)

quote($string):給字元串添加引號。

To-upper-case() 函數將字元串小寫字母轉換成大寫字母

To-lower-case() 函數將字元串轉換成小寫字母

 

(2)    數字函數

      percentage($value):將一個不帶單位的數轉換成百分比值;

      round($value):將數值四捨五入,轉換成一個最接近的整數;

      ceil($value):將大於自己的小數轉換成下一位整數;

      floor($value):將一個數去除他的小數部分;

      abs($value):返回一個數的絕對值;

      min($numbers…):找出幾個數值之間的最小值;

      max($numbers…):找出幾個數值之間的最大值;

      random(): 獲取隨機數

列表函數

(1)     length($list):返回一個列表的長度值;

(2)     nth($list, $n):返回一個列表中指定的某個標簽值($n必須是大於 0 的整數)

(3)     join($list1, $list2, [$separator])

將兩個列給連接在一起,變成一個列表,多於2個會出錯,但很多時候不只碰到兩個列表連接成一個列表,這個時候就需要將多個 join() 函數合併在一起使用。參數 $separator,這個參數主要是用來給列表函數連接列表值是,使用的分隔符號,預設值為 auto, 除了預設值 auto 之外,還有 comma 和 space 兩個值,其中 comma 值指定列表中的列表項值之間使用逗號(,)分隔,space 值指定列表中的列表項值之間使用空格( )分隔。

(1)                       第一個列表中只有一個列表項,那麼 join() 函數合併的列表項目中每個列表項目這間使用的分隔符號會根據第二個列表項中使用的

(2)                       如果列表中的第一個列表中每個值之間使用的是空格

(3)                       如果當兩個列表中的列表項小於1時,將會以空格分隔

(4)     append($list1, $val, [$separator]):將某個值放在列表的最後;

1)        如果列表只有一個列表項時,那麼插入進來的值將和原來的值會以空格的方式分隔。

2)        如果列表中列表項是以空格分隔列表項,那麼插入進來的列表項也將以空格分隔;

3)        如果列表中列表項是以逗號分隔列表項,那麼插入進來的列表項也將以逗號分隔。

4)        當然,在 append() 函數中,可以顯示的設置 $separator 參數,

如果取值為 comma 將會以逗號分隔列表項

如果取值為 space 將會以空格分隔列表項

(5)     zip($lists…):將幾個列表結合成一個多維的列表;

1)        在使用zip()函數時,每個單一的列表個數值必須是相同的,同類型

2)        zip(1px 2px 3px,solid dashed dotted,green blue red)生成

               1px solid green, 2px dashed blue, 3px dotted red

(6)     index($list, $value):返回一個值在列表中的位置值。index(1px solid red, red)

Introspection函數

(1)     type-of($value):返回一個值的類型

  • number 為數值型。 (帶單位和沒帶單位都可以)
  • string 為字元串型。
  • bool 為布爾型。
  • color 為顏色型

(2)     unit($number):返回一個值的單位,如果有運算的時候,加減要同單位,乘除可以多單位

(3)     unitless($number):判斷一個值是否帶有單位,返回boolean值

(4)     comparable($number-1, $number-2):判斷兩個值是否可以做加、減和合併,返回boolean值。同單位或者一個不帶單位的才可以,或者單位同類型

Miscellaneous函數(三元)

if($condition,$if-true,$if-false) // $condition是boolean值

Map(數據地圖/json 以 key:value 成對的出現)

用個 $ 加上命名空間來聲明 map。後面緊接是一個小括弧 (),將數據以 key:value 的形式賦予,其中 key 和 value 是成對出現,並且每對之間使用逗號 (,) 分隔,其中最後一組後面沒有逗號。

map可以相互嵌套

$theme-color: (
    default: (
        bgcolor: #fff,
        text-color: #444,
        link-color: #39f
    ),
    primary:(
        bgcolor: #000,
        text-color:#fff,
        link-color: #93f
    ),
    negative: (
        bgcolor: #f36,
        text-color: #fefefe,
        link-color: #d4e
    )
);

Sass Maps的函數

(1)     map-get($map,$key):根據給定的 key 值,返回 map 中相關的值。

根據 $key 參數,返回 $key 在 $map 中對應的 value 值。如果 $key 不存在 $map中,將返回 null 值

(2)     map-merge($map1,$map2):將兩個 map 合併成一個新的 map。

(3)     map-remove($map,$key):從 map 中刪除一個 key,返回一個新 map。

(4)     map-keys($map):返回 map 中所有的 key。

(5)     map-values($map):返回 map 中所有的 value。

(6)     map-has-key($map,$key):根據給定的 key 值判斷 map 是否有對應的 value 值,如果有返回 true,否則返回 false。

(7)     keywords($args):返回一個函數的參數,這個參數可以動態的設置 key 和 value。

@mixin map($args...){

    @debug keywords($args);

}

@include map(

  $dribble: #ea4c89,

  $facebook: #3b5998,

  $github: #171515,

  $google: #db4437,

  $twitter: #55acee

);

RGB顏色函數

開啟 Sass 的函數計算:sass -i

(1)      rgb($red,$green,$blue):根據紅、綠、藍三個值創建一個顏色;

(2)      rgba($red,$green,$blue,$alpha):根據紅、綠、藍和透明度值創建一個顏色;

(3)  rgba($red,$green,$blue,$alpha)  //將一個rgba顏色轉譯出來,和未轉譯的值一樣

(4)  rgba($color,$alpha)  //將一個Hex顏色轉換成rgba顏色

(5)      red($color):從一個顏色中獲取其中紅色值;

(6)      green($color):從一個顏色中獲取其中綠色值;

(7)      blue($color):從一個顏色中獲取其中藍色值;

(8)      mix($color-1,$color-2,[$weight]):把兩種顏色混合在一起。

$weight 為 合併的比例(選擇權重),預設值為 50%,其取值範圍是 0~1 之間。它是每個 RGB 的百分比來衡量,當然透明度也會有一定的權重。預設的比例是 50%,這意味著兩個顏色各占一半,如果指定的比例是 25%,這意味著第一個顏色所占比例為 25%,第二個顏色所占比例為75%。

HSL函數

(1)      hsl($hue,$saturation,$lightness):通過色相(hue)、飽和度(saturation)和亮度(lightness)的值創建一個顏色;

(2)      hsla($hue,$saturation,$lightness,$alpha):通過色相(hue)、飽和度(saturation)、亮度(lightness)和透明(alpha)的值創建一個顏色;

(3)      hue($color):從一個顏色中獲取色相(hue)值;

(4)      saturation($color):從一個顏色中獲取飽和度(saturation)值;

(5)      lightness($color):從一個顏色中獲取亮度(lightness)值;

(6)      adjust-hue($color,$degrees):通過改變一個顏色的色相值,創建一個新的顏色;

第二個值可以是度數,也可以是百分比

(7)      lighten($color,$amount):通過改變顏色的亮度值,讓顏色變亮,創建一個新的顏色;

(8)      darken($color,$amount):通過改變顏色的亮度值,讓顏色變暗,創建一個新的顏色;

(9)      saturate($color,$amount):通過改變顏色的飽和度值,讓顏色更飽和,從而創建一個新的顏色

(10)  desaturate($color,$amount):通過改變顏色的飽和度值,讓顏色更少的飽和,從而創建出一個新的顏色;

(11)  grayscale($color):將一個顏色變成灰色,相當於desaturate($color,100%);

(12)  complement($color):返回一個補充色,相當於adjust-hue($color,180deg);

(13)  invert($color):反回一個反相色,紅、綠、藍色值倒過來,而透明度不變。

Opacity函數

(1)      alpha($color) / opacity($color):獲取顏色透明度值;

(2)      rgba($color, $alpha):改變顏色的透明度值;

(3)      opacify($color, $amount) / fade-in($color, $amount):使顏色更不透明;

接受兩個參數,第一個參數是原始顏色,第二個參數是你需要增加的透明度值,其取值範圍主要是在 0~1 之間。當透明度值增加到大於 1 時,會以 1 計算,表示顏色不具有任何透明度。

(4)      transparentize($color, $amount) / fade-out($color, $amount):使顏色更加透明。

讓透明值做減法運算,當計算出來的結果小於 0 時會以 0 計算,表示全透明

@media

(1)      如果在樣式中使用 @media 指令,它將冒泡到外面

@at-root  跳出根元素

不會嵌套,樣式獨立

@debug  調試

@warn

@error

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在一個招聘網站中,通過限制用戶選擇職位標簽個數,可以精確定位用戶的職位。例如,以覆選框的形式為用戶提供一下備選職位標簽,限制用戶最多選擇3個,當超過三個時禁止用戶繼續選擇。 覆選框在問卷調查,招聘網站用的很廣,今天來介紹一下限制覆選框最多選擇幾項的方法: 思路: 監聽覆選框的onclick事件 監聽 ...
  • 一.簡介 Processing.js作者是John Resig,這是繼Jquery之後,他的第二個力作。 Processing.js提供了教學可視化的編程語言及運行環境。通過編寫processing程式,教師可以將複雜的物理、化學、數學原理形象的展示給學生。比如繪製各種曲線圖,波線,粒子,繪製分子結 ...
  • Div層拖動效果圖: 實現: CSS: View Code <style> div { position:relative; } </style> JS: View Code <script type="text/javascript"> var mouseover=true var xcoor; ...
  • 在JavaScript 中,this的指向是動態變化的,很可能在寫程式的過程中,無意中破壞掉this的指向,所以我們需要一種可以把this的含義固定的技術,於是就有了call,apply 和bind這三個方法,來改變函數體內部 this 的指向,因為函數存在「定義時上下文」和「運行時上下文」以及「上 ...
  • <!doctype html><html><head><meta charset="utf-8"><title>CSS壓縮混淆 / 格式化 / 美化工具</title><style type="text/csss">@charset "utf-8";/* CSS Document */ *{marg ...
  • CSS有一種基礎設計模式叫盒模型,定義了Web頁面中的元素是如何看做盒子來解析的。每一個盒子有不同的展示界面,下麵就來介紹盒模型,主要有一下幾種盒模型:inline、inline-block、block、table、absolute position、float。瀏覽器把每個元素看做一個盒模型,每個 ...
  • 《用electron製作俄羅斯方塊游戲》 後續文章,智能程式玩俄羅斯方塊游戲。 背景 前不久用ES6完成了基本的俄羅斯方塊游戲,今天已經完成了一個初步的智能演算法,可以自動玩俄羅斯方塊了,讓自己的想法朝實現更近了一步。 效果圖 第一次運行,消除了1398行,竊喜! 程式結構 主要關註智能演算法,結構簡單 ...
  • 無論你是新開發者還是經驗豐富的老程式員,前端框架可以有效地在開發的早期階段提升開發效率。在這篇文章中,我們選擇了15個新框架分享給開發人員,你肯定會想嘗試一下這些新鮮的框架。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...