摘要:本來想自己寫一篇關(guān)于入門的文章。后面可能在這篇文章基礎(chǔ)上,有所內(nèi)容的增加。預(yù)處理器定義了一種新的專門的編程語言,編譯后成正常的文件。
本來想自己寫一篇關(guān)于vue入門的文章。但是看到鏈接的文章后,覺得寫得太詳細(xì)了,實(shí)在有保存下來的必要。后面可能在這篇文章基礎(chǔ)上,有所內(nèi)容的增加。
CSS預(yù)處理器
定義了一種新的專門的編程語言,編譯后成正常的CSS文件。為CSS增加一些編程的特性,無需考慮瀏覽器的兼容問題,讓CSS更加簡潔,適應(yīng)性更強(qiáng),可讀性更佳,更易于代碼的維護(hù)等諸多好處。
CSS預(yù)處理器語言:scss(sass)、LESS等;
2.Sass和SCSS的區(qū)別
文件擴(kuò)展名不同:“.sass”和“.scss”;
Sass是以嚴(yán)格縮進(jìn)式語法規(guī)則來書寫的,不帶大括號和分號;而SCSS的語法和CSS書寫語法類似。
3.Sass安裝(Windows版)
先安裝ruby:Ruby 的官網(wǎng)(http://rubyinstaller.org/down...)下載對應(yīng)需要的 Ruby 版本
Paste_Image.png
安裝sass:
方法一(通過命令安裝sass):打開命令終端,輸入:gem install sass
方法二(本地安裝sass):從http://rubygems.org/gems/sass 下載sass安裝包,然后在終端輸入: “gem install <把下載的安裝包拖到這里>” 然后直接額回車即可安裝成功。
4.scss語法格式
css代碼:
body { font: 100% Helvetica, sans-serif; color: #333; }
使用scss代碼:
$font-stack: Helvetica, sans-serif; $primary-color: #333; body { font: 100% $font-stack; color: $primary-color; }
tip:如果使用sass舊語法(sass語法),文件后綴名應(yīng)為“.sass”;如果使用sass新語法(scss語法),文件后綴名應(yīng)為".scss“語法,否則編譯時編譯不出來。
sass編譯
5.1 sass編譯的方法:
命令編譯
GUI工具編譯
自動化編譯
5.1.1 sass命令編譯(在命令終端輸入sass指令來編譯sass,最直接,最簡單)
單文件編譯:
sass <要編譯的Sass文件路徑>/style.scss:<要輸出CSS文件路徑>/style.css
多文件編譯:
sass sass/:css/
上面的命令表示將項(xiàng)目中“sass”文件夾中所有“.scss”(“.sass”)文件編譯成“.css”文件,并且將這些 CSS 文件都放在項(xiàng)目中“css”文件夾中。
缺點(diǎn)及解決方法:
缺點(diǎn):每次保存scss文件后都要重新編譯太麻煩;
解決方法:開啟“watch”功能:
sass --watch <要編譯的Sass文件路徑>/style.scss:<要輸出CSS文件路徑>/style.css
tip:文件路徑不要帶中文,如果有中文,watch功能無法正常使用。
6.sass嵌套輸出方式nested
只要在編譯的時候帶上參數(shù)“ --style nested”:
sass --watch test.scss:test.css --style nested
7.sass展開輸出方式expanded
在編譯的時候帶上參數(shù)“ --style expanded”:
sass --watch test.scss:test.css --style expanded
8.sass展開輸出方式compact
在編譯的時候帶上參數(shù)“ --style compact”:
sass --watch test.scss:test.css --style compact
9.sass展開輸出方式compressed
在編譯的時候帶上參數(shù)“ --style compressed”:
sass --watch test.scss:test.css --style compressed
10.sass變量聲明
$+變量名+:+變量值;
$width:200px;
11.普通變量和默認(rèn)變量
普通變量聲明后可以在全局范圍內(nèi)使用;
默認(rèn)變量僅需在值后面加上!default 即可;
默認(rèn)變量一般是用來設(shè)置默認(rèn)值,然后根據(jù)需求來覆蓋的,覆蓋的方式是在默認(rèn)變量之前重新聲明下變量即可。默認(rèn)變量的價值在進(jìn)行組件化開發(fā)的時候會非常有用。
$baseLineHeight: 2; $baseLineHeight: 1.5 !default; body { line-height: $baseLineHeight; }
編譯后的CSS代碼:
body { line-height:2; }
12.局部變量和全局變量
局部變量:在元素里面聲明的變量;
全局變量:在元素外面定義的變量;
全局變量的影子:和全局變量名字相同的局部變量叫做全局變量的影子。
$color:green;//全局變量 $width:200px;//全局變量 $height:200px;//全局變量 body { background-color:$color;//調(diào)用全局變量 } div { $color:yellow;//定義局部變量,全局變量$color的影子 .div { background-color:$color;//調(diào)用局部變量 width:$width;//調(diào)用全局變量 height:$height;//調(diào)用全局變量 } }
13.sass嵌套
13.1 選擇器嵌套
css: nav a { color:red; } header nav a { color:green; } scss: nav { a { color: red; header & { color:green; } } }
13.2 屬性嵌套(有相同的屬性前綴)
css: .box { font-size: 12px; font-weight: bold; } scss: .box { font: { size: 12px; weight: bold; } }
13.3 偽類嵌套
scss: .clearfix{ &:before, &:after { content:""; display: table; } &:after { clear:both; overflow: hidden; } } css: clearfix:before, .clearfix:after { content: ""; display: table; } .clearfix:after { clear: both; overflow: hidden; }
sass混合宏
14.1 聲明混合宏
@mixin border-radius { -webkit-border-radius: 5px; border-radius: 5px; }
@mixin :聲明混合宏的關(guān)鍵詞;
border-radius:混合宏的名稱;
大括號內(nèi):復(fù)用的樣式代碼;
14.2 調(diào)用混合宏
@mixin border-radius{ -webkit-border-radius: 3px; border-radius: 3px; }//聲明混合宏border-radius button { @include border-radius; }//調(diào)用混合宏border-radius
編譯為CSS:
button { -webkit-border-radius: 3px; border-radius: 3px; }
14.3 混合宏的參數(shù)
不帶任何值的參數(shù)
@mixin border-radius($radius){ -webkit-border-radius: $radius; border-radius: $radius; }//聲明一個帶有參數(shù)$radius的混合宏 .box { @include border-radius(3px);//調(diào)用混合宏并給混合宏傳參數(shù)“3px” } 傳一個帶值參數(shù)(傳入一個默認(rèn)值) @mixin border-radius($radius:3px){ -webkit-border-radius: $radius; border-radius: $radius; }//聲明一個傳入了默認(rèn)參數(shù)值的混合宏 .btn { @include border-radius;//使用默認(rèn)參數(shù)值的混合宏 } .box { @include border-radius(50%);//可以自己傳入?yún)?shù)值 }
編譯出來的CSS:
.btn { -webkit-border-radius: 3px; border-radius: 3px; } .box { -webkit-border-radius: 50%; border-radius: 50%; }
傳多個參數(shù)值
@mixin size($width,$height){ width: $width; height: $height; } .box-center { @include size(500px,300px); }
編譯出來的css:
.box-center { width: 500px; height: 300px; }
15.sass 繼承
scss:
.btn { border: 1px solid #ccc; padding: 6px 10px; font-size: 14px; } .btn-primary { background-color: #f36; color: #fff; @extend .btn; }
編譯出來后:
.btn, .btn-primary { border: 1px solid #ccc; padding: 6px 10px; font-size: 14px; } .btn-primary { background-color: #f36; color: #fff; }
在sass中的繼承,可以繼承類樣式塊中所有樣式代碼,而且編譯出來的css會將選擇器合并在一起,形成組合選擇器。
16.sass占位符%
用占位符聲明的代碼,如果不被@extend調(diào)用就不會被編譯。
%mt5 { margin-top: 5px; } %pt5{ padding-top: 5px; } .btn { color:red; }
編譯后:
.btn { color:red; }//%占位符聲明的代碼沒有被編譯產(chǎn)生css代碼
使用@extend調(diào)用:
%mt5 { margin-top: 5px; } %pt5{ padding-top: 5px; } .btn { @extend %mt5;//使用@extend調(diào)用占位符代碼 @extend %pt5; } .block { @extend %mt5; span { @extend %pt5; } }
編譯后的css代碼:
.btn, .block { margin-top: 5px; } .btn, .block span { padding-top: 5px; }
通過@extend調(diào)用的占位符,編譯出來的代碼會將相同的代碼合并在一起,代碼變得十分簡潔。
17.sass插值
$properties: (margin, padding); @mixin set-value($side, $value) { @each $prop in $properties {//對每個在$properties中的$prop,即$properties中的margin、padding #{$prop}-#{$side}: $value;//$prop連接參數(shù)$side,值為參數(shù)$value } } .login-box { @include set-value(top, 14px);//調(diào)用混合宏 }
編譯出來的css:
.login-box { margin-top: 14px; padding-top: 14px; }
不可以:
$margin-big: 40px; $margin-medium: 20px; $margin-small: 12px; @mixin set-value($size) { margin-top: $margin-#{$size}; } .login-box { @include set-value(big); }
也不可以:
@mixin updated-status { margin-top: 20px; background: #F00; } $flag: "status"; .navigation { @include updated-#{$flag}; }
可以在使用@extend時使用插值:
%updated-status { margin-top: 20px; background: #F00; } .selected-status { font-weight: bold; } $flag: "status"; .navigation { @extend %updated-#{$flag}; @extend .selected-#{$flag}; }
sass 注釋
/注釋內(nèi)容/ :會在編譯出來的css文件中顯示
//注釋內(nèi)容 :不會在編譯出來的css文件中顯示
//定義一個占位符
%mt5 {
margin-top: 5px;
}
/調(diào)用一個占位符/
.box {
@extend %mt5;
}
編譯出來的css:
.box { margin-top: 5px; }
/調(diào)用一個占位符/
sass運(yùn)算
19.1 sass 加法/減法
變量或?qū)傩灾卸伎梢宰黾臃?減法運(yùn)算
.box { width: 20px + 8in; height:20px - 5px; }
編譯出來的css:
.box { width: 788px; height:25px; }
不用類型的單位做加法/減法會報錯:
.box { width: 20px + 1em;//不同類型單位不能做加法 }
19.2 sass 乘法
這樣子會有問題:
.box { width:10px * 2px; }
應(yīng)該這樣子:
.box { width: 10px * 2; }
編譯出來的css:
.box { width: 20px; }
同加法減法一樣,不同類型單位做乘法也會報錯。
19.3 sass除法
如果除式中沒有變量或者不是在一個數(shù)學(xué)表達(dá)式中(有加法減法等),就要將除式運(yùn)算用小括號括起來,否則“/”不會被當(dāng)做除號運(yùn)算。
p { font: 10px/8px; // 純 CSS,不是除法運(yùn)算 $width: 1000px; width: $width/2; // 使用了變量,是除法運(yùn)算 width: round(1.5)/2; // 使用了函數(shù),是除法運(yùn)算 height: (500px/2); // 使用了圓括號,是除法運(yùn)算 margin-left: 5px + 8px/2px; // 使用了加(+)號,是除法運(yùn)算 }
編譯出來的css:
p { font: 10px/8px;//這種是無意義的css width: 500px; height: 250px; margin-left: 9px; }
除法中相同單位相除不會報錯,會產(chǎn)生一個無單位的值:
.box { width: (1000px / 100px); }
編譯出來的css:
.box { width: 10; }
19.4 sass 變量計算
$content-width: 720px; $sidebar-width: 220px; $gutter: 20px; .container { width: $content-width + $sidebar-width + $gutter; }
編譯出來的css:
.container { width: 960px; }
19.5 sass數(shù)字運(yùn)算
.box { width: ((220px + 720px) - 11 * 20 ) / 12 ; }
編譯出來的css:
.box { width: 60px; }
19.6 sass顏色運(yùn)算
所有算術(shù)運(yùn)算都支持顏色值,并且是分段計算的。
p { color: #010203 + #040506; }
計算公式為 01 + 04 = 05、02 + 05 = 07 和 03 + 06 = 09, 并且被合成為:
p { color: #050709; }
數(shù)字和顏色一起運(yùn)算:
p { color: #010203 * 2; }
計算公式為 01 2 = 02、02 2 = 04 和 03 * 2 = 06, 并且被合成為:
p { color: #020406; }
19.7 sass 字符運(yùn)算
用“+”對字符串進(jìn)行連接:
$content: "Hello" + "" + "Sass!"; .box:before { content: " #{$content} "; }
編譯出來的css:
.box:before { content: " Hello Sass! "; }
可以使用“+”直接連接字符:
div { cursor: e + -resize; }
編譯出來的css:
div { cursor: e-resize; }
有引號的字符串和沒有引號的字符串相加,看哪個在“+”號的左邊,如果有引號的在左邊,結(jié)果為有引號的;如果沒有引號的在左邊,結(jié)果為沒有引號的:
p:before { content: "Foo " + Bar; font-family: sans- + "serif"; }
編譯出來的css:
p:before { content: "Foo Bar"; font-family: sans-serif; }
作者:恰皮
鏈接:https://www.jianshu.com/p/fa3...
來源:簡書
簡書著作權(quán)歸作者所有,任何形式的轉(zhuǎn)載都請聯(lián)系作者獲得授權(quán)并注明出處。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/114099.html
摘要:前端工程師學(xué)習(xí)資料,快速查找面試題,經(jīng)典技術(shù)文章的總結(jié),編程技巧,幫助學(xué)習(xí)者快速定位問題花點(diǎn)時間整理出一下前端工程師日常工作所需要的學(xué)習(xí)資料查找,幫助學(xué)習(xí)者快速掌握前端工程師開發(fā)的基本知識編程始于足下記住再牛逼的夢想也抵不住傻逼似的堅持蝴蝶 前端工程師學(xué)習(xí)資料,快速查找面試題,經(jīng)典技術(shù)文章的總結(jié),編程技巧,幫助學(xué)習(xí)者快速定位問題花點(diǎn)時間整理出一下web前端工程師日常工作所需要的學(xué)習(xí)資料...
摘要:這段時間學(xué)習(xí)還是邊擼小項(xiàng)目邊學(xué)比較容易掌握感謝無私提供的各種感謝每日一文這個我還是蠻喜歡的在線演示地址點(diǎn)我訪問手機(jī)直接訪問端打開開發(fā)者工具欄手機(jī)模式項(xiàng)目地址點(diǎn)我訪問技術(shù)棧功能設(shè)計今日文章主頁隨機(jī)一文前一天后一天的文章頂部進(jìn)度條自己的想 這段時間學(xué)習(xí)vue 還是邊擼小項(xiàng)目邊學(xué)比較容易掌握 感謝@jokermonn無私提供的各種API jokermonn/-Api 感謝 每日一文 這個a...
摘要:這段時間學(xué)習(xí)還是邊擼小項(xiàng)目邊學(xué)比較容易掌握感謝無私提供的各種感謝每日一文這個我還是蠻喜歡的在線演示地址點(diǎn)我訪問手機(jī)直接訪問端打開開發(fā)者工具欄手機(jī)模式項(xiàng)目地址點(diǎn)我訪問技術(shù)棧功能設(shè)計今日文章主頁隨機(jī)一文前一天后一天的文章頂部進(jìn)度條自己的想 這段時間學(xué)習(xí)vue 還是邊擼小項(xiàng)目邊學(xué)比較容易掌握 感謝@jokermonn無私提供的各種API jokermonn/-Api 感謝 每日一文 這個a...
摘要:這段時間學(xué)習(xí)還是邊擼小項(xiàng)目邊學(xué)比較容易掌握感謝無私提供的各種感謝每日一文這個我還是蠻喜歡的在線演示地址點(diǎn)我訪問手機(jī)直接訪問端打開開發(fā)者工具欄手機(jī)模式項(xiàng)目地址點(diǎn)我訪問技術(shù)棧功能設(shè)計今日文章主頁隨機(jī)一文前一天后一天的文章頂部進(jìn)度條自己的想 這段時間學(xué)習(xí)vue 還是邊擼小項(xiàng)目邊學(xué)比較容易掌握 感謝@jokermonn無私提供的各種API jokermonn/-Api 感謝 每日一文 這個a...
摘要:使用構(gòu)建單頁應(yīng)用新篇在去年的七月六號的時候,發(fā)布了一篇使用構(gòu)建單頁應(yīng)用的文章,文章主要是介紹的基本使用方法,發(fā)現(xiàn)對大部分的入門同學(xué)有很大的幫助,時至今日還有很多同學(xué)不斷的點(diǎn)贊與收藏,瀏覽量最高達(dá)到。 使用 Vuex + Vue.js 構(gòu)建單頁應(yīng)用【新篇】 在去年的七月六號的時候,發(fā)布了一篇 使用 Vuex + Vue.js 構(gòu)建單頁應(yīng)用 的文章,文章主要是介紹 vuex 的基本使用方法...
閱讀 3289·2023-04-26 02:09
閱讀 2589·2021-11-24 09:39
閱讀 3283·2021-11-16 11:52
閱讀 3621·2021-10-26 09:50
閱讀 2778·2021-10-08 10:05
閱讀 2463·2021-09-22 15:25
閱讀 3308·2019-08-30 13:14
閱讀 920·2019-08-29 17:06