Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Knowledge BBQ VOL.3
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
TAK WAT
January 18, 2017
Programming
390
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Knowledge BBQ VOL.3
TAK WAT
January 18, 2017
More Decks by TAK WAT
See All by TAK WAT
2021年にIE対応を断るのは間違っているだろうか
takwat
1
260
EFOのお話
takwat
1
300
Vueへの道
takwat
0
33
入り口としてのKnockout.js
takwat
0
400
Do You Like JobQueue?
takwat
0
75
Other Decks in Programming
See All in Programming
さぁV100、メモリをお食べ・・・
nilpe
0
140
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
550
Mujeres en SEO Summit 2026 - Greatest Disaster Hits en Web Performance
guaca
0
180
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
570
Webフレームワークの ベンチマークについて
yusukebe
0
170
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
710
CSC307 Lecture 17
javiergs
PRO
0
320
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
540
Creating Composable Callables in Contemporary C++
rollbear
0
150
Skillsは効率化、Agentsは"自分の拡張"——Builder時代のエージェント編成(CC Night 2026)
wemra
1
140
例外の正しい扱い方 そのエラー try-catchして大丈夫?
jinwatanabe
0
260
スマートグラスで並列バイブコーディング
hyshu
0
150
Featured
See All Featured
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
340
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
200
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
200
Amusing Abliteration
ianozsvald
1
210
Exploring anti-patterns in Rails
aemeredith
3
410
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
Java REST API Framework Comparison - PWX 2021
mraible
34
9.4k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
430
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
330
Producing Creativity
orderedlist
PRO
348
40k
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
410
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Transcript
SASS とCOMPASS でCSS をもう少し楽に書こう
自己紹介 青森県八戸市出身( 港と鯖とイカと工場の町です) アラフォー Twitter @_takwat Qiita 仙台市内某社社内SE https://qiita.com/khirose
社内SE ? 自社のシステムやクライアントPC のお守りがメインです ただし自社の事業サイトや一部受託開発もやってます どうせ自社でやるんだしってことで色々と取り入れてま す
サイトが育って増大してきたCSS に ありがちな辛いところ
クラス名が他とかぶって困惑 まあこれは命名規則でなんとかするしかない? → そうして長くなっていくクラス名 .top-navi-some-class
ネストが深くなってきて見通しがしにくい section > div { ... } section > div
> div { ... } section > div > div > ul > li { ... }
何か同じコードを何度もコピペしてる気が する .picture1{...} .picture2{...} .picture3{...} .picture4{...} .picture5{...} .picture6{...} 6 個ならまだいいけど100
個あったら?
ベンダープレフィックスつきのプロパティ 指定するのがつらい -webkit だけならともかくfilter:progid:DXImageTranform と か何だよって話
そこでSASS やってみませんか?
SASS とは? Syntactically Awesome Stylesheets 構文的に素晴らしいスタイルシート・・・?
もともとインデントで構文でした $blue: #3bbfce $margin: 16px .content-navigation border-color: $blue color: darken($blue,
10%) .border padding: $margin/2 margin: $margin/2 border-color: $blue 厳密にSass といえば↑ みたいな書き方のことらしく ※Python やYAML みたい
見慣れたブロック構文にスクリプ ト言語みたいな要素も入れて $blue: #3bbfce; $margin: 16px; .content-navigation { border-color: $blue;
color: darken($blue, 10%); } .border { padding: $margin / 2; margin: $margin / 2; border-color: $blue; } 現在の.scss に落ち着く
以上、WIKIPEDIA さんから
SASS の利点になりそうなコード例 を色々見てみよう 実質scss ですが 基本的に素のCSS を書いてもとくに文句は言わず、ほぼ そのまま出力してくれます
SASS のコード例(1) 入れ子 /* 感 書 */ .items{ font-size: 1vw;
h2{ font-size: 4vw; strong{ font-weight: bold; } } }
SASS のコード例(2) プロパティ /* font-* 書 */ h1{ font:{ family:
'......'; size: 1vw; weight: normal; } } セレクタは .example{} で まとめる場合のプロパティは font: {} とJSON 記法になるのがはまりどころ ※ 個人的にはあんまりオススメはしないですがmargin や padding 指定したいときは便利かも
SASS のコード例(3) 疑似要素 /* a 設定 疑似要素 含 感 */
a{ text-decoration: none; /* 自分自身 指 "&" */ &:hover{ text-decoration: underline; } }
SASS のコード例(4) 変数 /* 共通部分 変数化 */ $small-font-size: 1vw; $medium-font-size:
2vw; $larger-font-size: 4vw; $large-font-size: 8vw; h1{ font-size: $large-font-size; }
SASS のコード例(5) 継承 $mycolor: rgb(31,31,31); .alpha{ font-size: 2vw; color: $mycolor;
} .beta{ @extend .alpha; border: 1px solid $mycolor; } .alpha の中身(font-size とcolor) を.beta にそっくりそのまま 引き継いだ上でborder を追加指定 ※ これも意外とハマるのであまりオススメしないです (後述の@mixin のほうが使い勝手がよさげなんで)
SASS のコード例(6) 条件分岐 /* 当然if文 */ $type: ocean; p{ @if
$type == ocean { color: blue; } @else { color: black; } } /* if/else 1対 書 方 (Excel MySQL IF関数 近 ) */ h1{ /* type ocean blue, ocean以外 black */ color: if($type == ocean, blue, black); }
( 余談) 変数と条件分岐をメディアク エリと組み合わせ /* 組 合 */ $device-display: wide;
@media only screen and (max-width: 60rem) { $device-display: narrow; } /** 後 */ h1{ font-size: if($device-display == narrow, 8vw, 2vw); }
SASS のコード例(7) ループ /* 使 */ /* <li> 1~6番目 連番
名 別 背景 適用 */ li{ @for $i from 1 through 6{ &:nth-child(#{$i}){ background: linear-gradient( to bottom, rgba(255, 255, 255, 0.6), rgba(0, 0, 239, 0.1)), url('./img/button#{$i}.png' ) no-repeat; background-size: contain; background-position: center center; } } }
SASS のコード例(8) 関数(MIXIN) /* 一部 違 共通部分 */ /* $width:
1px, $color: #000 値 */ @mixin text-border($width: 1px, $color:#000){ text-shadow: 0 $width 0 $color, $width 0 0 $color, 0 (-$width) 0 $color, (-$width) 0 0 $color, (-$width) (-$width) 0 $color, $width (-$width) 0 $color, (-$width) $width 0 $color, $width $width 0 $color; } h1{ @include text-border(2px, #fff); /* 周辺2 白 縁取 */ }
SASS のコード例(9) PARTIAL と IMPORT 例えば、共通で使う変数やmixin などを $box-large-size: 40vw; $color-normal:
black; $color-warning: orange; $color-danger: red; のように定義し、_variables.scss として保存しておいて @import "variables"; .content{ width: $box-large-size; } のように複数の.scss で使いまわしができる
PARTIAL 関連 _ ではじまるファイル名はpartial として扱われる partial は他のファイルから@import される前提のファ イルで単独では変換処理の対象にはされない つまり、_variables.css
みたいなものは生成されない @import は拡張子不要 partial の場合、_ も不要 _variables.scss とvariables.scss が同時にあったら @import はどうなるんでしょうね→ 警告出ました
でもよく使うアレやアレをMIXIN と かで定義しなおすの辛い
もしかしてCOMPASS にない?
COMPASS http://compass-style.org/ Sass の「あるある」をまとめたライブラリ
例) 角丸のボックス(BEFORE) @import 'compass'; .radius { @include border-radius; }
例) 角丸のボックス(AFTER) .radius { -webkit-border-radius: 5px; -moz-border-radius: 5px; -ms-border-radius: 5px;
-o-border-radius: 5px; border-radius: 5px; }
大きな利点 ベンダープレフィックスもバッチリ compass じゃなくてもSass 単体でやれる方法もある 今回はcompass は深掘りしないので単体での方法でやり ます
他 シャドウやグラデーション、スプライトの作成まで @ なんちゃら( ちょっとしたパラメータ) で色々やってくれるのでドキュメント参照 compass までやると今回の尺が足りないので今回は入り 口の紹介のみ
では環境を作ろう ruby のインストール sass コマンドをインストールする
・・・敷居高杉内?
そこでKOALA http://koala-app.com/
やること GUI で設定して ソースの入ったディレクトリをドラッグ&ドロップ あとはKoala が立ち上がっている間は↑ のディレクトリに ある.scss なファイルが更新されたら自動で同じディレク トリにcss
まで作ってくれる
設定(1) UI の日本語化
設定(2) SASS の設定 SourceMap 出力( このCSS はどのSass から変換されたか がわかるのでデバッグ時にはかどります) ベンダープレフィックスの自動付与
None
設定(3) CSS の設定 ぐしゃっと1 行にまとめてmin.css を作るとかもありま すが今回はあまりさわらないほうがいいかも
None
SCSS を書いて動かしてみよう