sass和compass基礎用法

一、基本命令

  • sass都是通過gem安裝,以下是一些基礎的命令
移除ruby的鏡像地址
gem sources --remove https://rubygems.org/添加淘寶的鏡像 
gem source -a http://ruby.taobao.org查看鏡像 gem source -v單文件轉換命令
sass style.scss style.css單文件監聽命令(監聽會自動編譯)
sass --watch style.scss:style.css文件夾監聽命令
sass --watch sassFileDirectory:cssFileDirectorycss文件轉成sass/scss文件(在線轉換工具css2sass)
sass-convert style.css style.sass
sass-convert style.css style.scss運行命令行幫助文檔,可以獲得所有的配置選項
sass -h--style表示解析后的css是什么格式,有四種取值分別為:nested,expanded,compact,compressed
sass --watch style.scss:style.css --style compact----------------以下是compass-----------compass創建一個編譯目錄,會生成config.rb文件,里面是一些配置
compass create sassAPPcompass編譯
compass compile
compass compile --forcecompass監視
compass watch
compass watch --force

二、sass基礎語法

1、變量

// 變量默認值,默認20px,但賦值后為18px
$fontsize:18px;
$fontsize:20px !default;
p {font-size: $fontsize; //18px
}// 多值變量:可以直接使用,也可以當做一個數組從中取值
$paddings:7px 10px 9px 8px;
$many:(color:red,font-size:24px,border:solid 1px blue); // 像是一個數組
.btn{padding:$paddings; // 直接使用padding-left:nth($paddings,2); // 當做數組,從中取值background-color:map_get($many,color); // 當做數組,從中取值border:map_get($many,border); // 當做數組,從中取值
}
// 編譯后
.btn {padding: 7px 10px 9px 8px;padding-left: 10px;background-color: red;border: solid 1px blue;
}// 局部變量和全局變量
body{// 局部變量,不能用在footer中$color:red;color:$color;// 全局變量$font-size:16px !global;
}
footer{// color:$color; // 不可以使用局部變量font-size: $font-size; // 可以使用全局變量
}// 變量用在選擇器上
$className:main;
.#{$className}{margin:10px;padding:5px;
}// 變量中的下劃線和減號意義相同
$text-info:blue;
$text_info:red;
section{color:$text-info;
}

2、嵌套和繼承

body{background-color:red;// 選擇器嵌套header{background-color:green;}// 屬性嵌套footer{background:{color:red;size:100% 50%;}}a{// 引用父選擇器&:hover{color:blue;}&.contain{background-color:yellow;}}
}// 繼承與多繼承
.alert{background-color: #FED;
}
.small{font-size:12px;
}
.alert-info{@extend .alert;@extend .small;// 用以下方法代替// @extend .alert,.small;
}// 鏈式繼承
.one{border:solid 1px red;
}
.two{@extend .one;color:blue;
}
.three{@extend .two;border-radius:5px;
}// 占位選擇器 不會生成得到css中
%alert{color:green;
}
.alert-danger{@extend %alert;
}

3、數值類型和mixin

// 數字類型
$n1:1.2;
$n2:12;
$n3:14px;
.body{font-size:$n3;
}
// 字符串類型
$s1:container;
$s2:'container';
$s3:"container";
.#{$s1}{font-size:$n3;
}
// 布爾類型
$bt:true;
$bf:false;// null類型
$null:null;
body{@if($null==null){color:red;}
}
// 顏色類型
$c1:blue;
$c2:#fff;
$c3:rgba(255,255,0,0.5);
body{color:$c3;
}// 加減乘除
$width1:12px;
$width2:13px;
body{width:$width1+$width2;.header{width:$width1 -$width2;}
}
a:before{content:'A'+bc;
}
a:before{content:A+'bc';
}
p{padding:3px + 4px auto;
}$version:3;
p:before{// 使用變量的方法content:'hello,sass #{$version}'
}
p{font-size:20px/10px;font-size:(20px/10px);width:$width2/2;height:round($width2)/2;
}// 引用片段
@mixin cont{color:red;font-size:18px;
}
// 函數功能,:blue可以去掉
@mixin cont1($color:blue){color:$color;
}
// 多參數函數
@mixin cont2($color,$font-size){color:$color;font-size:$font-size;
}
body{@include cont;@include cont1(green);@include cont2(green,20px);
}
p{@include cont2($font-size:good,$color:green);
}// 多數值函數,變量個數可變
@mixin box-shadow($box-shadow...){-webkit-box-shadow: $box-shadow;-moz-box-shadow: $box-shadow;box-shadow: $box-shadow;
}
body{@include box-shadow(2px 2px 0px blue,-2px -2px 0px green);
}// 內容傳遞
@mixin style-for-iphone{@media only screen and (max-width:768px) and (min-width:240px){margin: 10px;@content;}
}
@include style-for-iphone{font-size:24px;background-color:#fff;
}
// 編譯后
@media only screen and (max-width: 768px) and (min-width: 240px) {margin: 10px;font-size: 24px;background-color: #fff;
}

4、函數、調試(一般也用不上)

// 自定義函數
@function double($width){@return $width*2;
}
.container{width:double(5px);
}$color:rgb(255,0,255);
body{color:$color;background-color:rgba(255,255,0,0.5);border-color:rgba($color,0.5);width:500px;height:500px;p{// 顏色加深函數color:darken($color,5);background-color:lighten($color,5);// 奇葩函數,誰會這么用?z-index:str-length('hello world'); // 11a-index:str-index('abcdefg','d'); // 4}
}
// 測試判斷所用,控制臺輸出
// @debug 'This is a debug test';
// @warn 'Warn';
// @error 'Error';
@function Three($width){@if($width>3){@error '$width is error';}@return $width*3;
}
body{width:#{Three(2)}px;; // 6px
}@function getIndex($layer:default){$zIndexMap:(default:1,modal:100,dropdown:500,grid:300);$z-index:1;@if map-has_key($zIndexMap,$layer) {$z-index:map_get($zIndexMap,$layer);}@return $z-index;
}
p{z-index:getIndex(modal);z-index:getIndex(abc);
}
// 編譯后
p {z-index: 100;z-index: 1;
}

5、條件語句、循環

// if三目運算
$screenWidth:600px;
body{color:if($screenWidth>768px,blue,red);
}// if條件語句
body{@if $screenWidth>768px{color:red;}@else if $screenWidth<500px{color:blue;}@else{color:green;}
}// for循環 through包含5,而to不包含5
@for $i from 1 through 5{span#{$i}{width:20%*$i;}
}// while循環
$j:5;
@while $j>0{.div#{$j}{width:20%*$j;}$j: $j - 2;
}// each常規遍歷
$k:1;
@each $c in red blue green yellow{.section#{$k}{background-color:$c;}$k:$k+1;
}// each list遍歷
@each $key,$color in (default,blue),(info,green),(danger,red){.text-#{$key}{background-color:$color;}
}// each map遍歷
@each $key,$color in (default:blue,info:green,danger:red){.label-#{$key}{background-color:$color;}
}@function screenDivide($Num){$num:$Num;$map:(defaultvalue:0);@for $i from 1 to $num{$mapValue:(#{$i}:percentage(1/$num)*$i);$map:map-merge($map,$mapValue);}$map:map_remove($map,defaultvalue);@return $map;
}
@each $key,$value in screenDivide(5){.slider#{$key}{width:$value;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/276284.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/276284.shtml
英文地址,請注明出處:http://en.pswp.cn/news/276284.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

字節面試官:如何實現Ajax并發請求控制

偷偷告訴你&#xff0c;點此抽獎送紅包還送3本比紅寶書還貴的書實現一個批量請求函數 multiRequest(urls, maxNum)&#xff0c;要求如下&#xff1a; ? 要求最大并發數 maxNum ? 每當有一個請求返回&#xff0c;就留下一個空位&#xff0c;可以增加新的請求 ? 所有請求完成后…

Jquery 中 ajaxSubmit使用講解

轉載鏈接&#xff1a;http://blog.csdn.net/h70614959/article/details/8810270 1 引入依賴腳本 <script type"text/javascript" src"/js/jquery/jquery.form.js"></script> //ajaxForm 依賴腳本<script type"text/javascript"…

接口與抽象類

接口中的屬性 默認是 public static final類型 就算你不加 默認也是存在 方法默認都是public abstract類型 不加默認也存在 比如 interface K { String abc"sdfd"; void add() throws Exception; } 實際上編譯時 是這樣 interface K { Public static final String a…

制造行業電子化簽約及印控一體化解決方案

當生產“智造化”、營銷“數字化”成為趨勢&#xff0c;生產制造型企業如何實現產品生產-銷售全流程提速降本&#xff1f;生產制造型企業為了在生產、營銷環節降低成本、提升效率&#xff0c;經營模式上常有如下特征&#xff1a;? 原料導向&#xff0c;多點協同生產&#xff1…

python 點擊按鈕采集圖片_python多線程采集圖片

cmd中運行>python untitled2.py 圖片的網站import requestsimport threadingfrom bs4 import BeautifulSoupimport sysimport osif len(sys.argv) ! 2:print("Usage : " )print(" python main.py [URL]" )exit(1)# config-starturl sys.argv[1]thre…

一起手寫Vue3核心模塊源碼,掌握閱讀源碼的正確方法

最近和一個獵頭聊天&#xff0c;說到現在前端供需脫節的境況。一方面用人方招不到想要的中高級前端&#xff0c;另一方面市場上有大量初級前端薪資要不上價。特別是用 Vue 框架的&#xff0c;因為好上手&#xff0c;所以很多人將 Vue 作為入門框架&#xff0c;但學得深的人并不…

jquery|javascript 回車事件

轉載鏈接&#xff1a;http://www.cnblogs.com/wenbo/archive/2011/08/20/2147014.html 轉載鏈接: http://www.2cto.com/kf/201202/119741.html jquery實現回車事件&#xff0c;代碼如下&#xff1a; 全局&#xff1a; $(function(){ document.onkeydown function(e){…

【Vegas原創】ASP 0131 不允許父路徑的解決

現象&#xff1a; Active Server Pages 錯誤 ASP 0131 不允許的父路徑 /admin/login.asp&#xff0c;行 2 包含文件 ../include/config.asp 不能用 .. 表示父目錄。 解決方案&#xff1a; IIS6>站點屬性>主目錄>配置>選項>啟用父路徑 轉載于:https://www.cnblog…

騰訊正式宣布成立技術委員會,要對組織架構下狠手

2019 年伊始&#xff0c;社交巨人騰訊正式宣布成立技術委員會&#xff0c;計劃在未來發力內部代碼的開源和協同&#xff0c;投入更多資金和精力在技術建設上。BAT 三家里一直被詬病技術建設落后的騰訊&#xff0c;終于開始補足自己的短板。這會對騰訊自身帶來什么&#xff1f;又…

2020 前端技術發展回顧

大家好&#xff0c;我是若川&#xff0c;今天給大家分享一篇來自阿里媽媽前端快爆的好文。另外&#xff0c;偷偷告訴你&#xff0c;截止今晚9點 點此抽獎送紅包還送3本比紅寶書還貴的書可以點擊文章末尾閱讀原文直達知乎鏈接&#xff0c;以下是正文2020 終究是一個不平凡的一年…

php驗證碼函數 使用imagestring() imagefttext()設置字體大小

轉載路徑&#xff1a;http://hi.baidu.com/asdasd_cn/item/62977d1e26ca36e85e53b142 生成驗證碼圖片的兩個函數 第一個是用imagestring bool imagestring ( resource $image , int $font , int $x , int $y , string $s , int $col ) imagestring() 用 col …

提取地圖中道路_非機器學習方法·從遙感影像中提取道路

本科低年級曾經做過一個提取道路線的題目。提供的數據&#xff1a;老師給我們了一幅學校周邊地區的影像&#xff0c;包括RGBInfrared四個波段。一開始使用的方法&#xff1a;當時尚青澀的我和小伙伴們一起使用KMEANS、閾值分割等等方法試圖將那道路從影像中分離出來。遇到的問題…

圖片尺寸自適應

圖片尺寸自適應 οnlοad"javascript:if(this.height>this.width){this.height100}else{this.width100} 轉載于:https://www.cnblogs.com/TangZhongxin/archive/2009/12/14/3942483.html

第一章知識點

第一章知識點 一&#xff1a;SQL語言 1&#xff0c;結構化查詢語言&#xff0c;是關系數據庫的標準語言 2&#xff0c;分類&#xff1a; 2.1&#xff1a;數據操作語言&#xff1a;DML&#xff1b;包括&#xff1a;即增刪查改&#xff1b;insert&#xff0c;update&#xff0c;d…

2021年,推薦這幾個優質公眾號碎片化學習

2021 年了&#xff0c;前端技術日新月異&#xff0c;發展迅速&#xff0c;前端公眾號是不是感覺越來越多了&#xff1f;在著辭舊迎新之際&#xff0c;這里盤點幾個前端開發工程師 2021 年必須關注的優質公眾號&#xff0c;希望對你有所幫助。大家可以像我一樣&#xff0c;利用碎…

php 處理表單里面的 單雙引號

轉載鏈接&#xff1a;http://developer.51cto.com/art/200911/165392.htm 我們今天要向大家介紹的是PHP magic_quotes_gpc的具體使用方法。大家都知道在PHP中一個特殊的函數魔術函數&#xff0c;它在引用的過程中只有在傳遞$_GET,$_POST,$_COOKIE時才會發生作用。 PHP函數preg…

阿里云插件新版發布,多特性助力提升開發者體驗

好消息&#xff01;阿里云 Cloud Toolkit 新版本于近日正式發布&#xff0c;推出了面向 IntelliJ 和 Eclipse 兩個平臺的新款插件&#xff0c;多個重大特性&#xff0c;持續提升開發者體驗&#xff0c;本文將帶大家快速預覽該新版本。 本文只挑選下面三個重大特性進行解讀&…

海鷗表表帶太長了怎么拆_表帶安裝,表帶太長了,怎么拆解和安裝?

表帶太長了&#xff0c;怎么拆解和安裝&#xff1f;1、準備拆表帶前請看清楚表帶背面的箭頭。2、有箭頭的帶粒是可拆卸的。3、擰松拆帶器把手&#xff0c;將表帶放入表槽&#xff0c;并保持拆帶器的鋼針對準針孔&#xff0c;如圖二&#xff0c;且拆帶器的鋼針順著箭頭的指示方向…

python類庫31[文件和目錄os+os.path+shutil]

一 常用函數 os模塊 os.sep 表示默認的文件路徑分隔符&#xff0c;windows為\, linux為/os.walk(spath): 用來遍歷目錄下的文件和子目錄os.listdir(dirname)&#xff1a;列出dirname下的目錄和文件os.mkdir() &#xff1a; 創建目錄os.makedirs(): 創建目錄&#xff0c;包含中間…

上一輪中獎信息公布

大家好&#xff0c;我是若川&#xff0c;抽獎活動其實挺耗時耗力的&#xff0c;尤其是留言和在看抽獎。比如我這篇文章寫完就已經23:50了。特別想說的是&#xff1a;有126人點擊了在看&#xff0c;但我的好友展示只有93人在看。說明還有30多人點擊了在看&#xff0c;但忘記加我…