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
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
依存関係から依存物へ―Dependencyという言葉の歴史をひも解く
j_lee
0
120
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
570
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
270
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
710
RTSPクライアントを自作してみた話
simotin13
0
610
Dataformのリポジトリを立ち上げるときにまずやること / dataform-day0-2026
snhryt
0
170
AIとASP.NET Coreで雑Webアプリを作った話
mayuki
0
650
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
250
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
250
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
120
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
13k
A2UI という光を覗いてみる
satohjohn
1
140
Featured
See All Featured
The Curious Case for Waylosing
cassininazir
1
390
Navigating Weather and Climate Data
rabernat
0
220
A Soul's Torment
seathinner
6
2.9k
Automating Front-end Workflow
addyosmani
1370
210k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
300
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
Building AI with AI
inesmontani
PRO
1
1.1k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
180
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
430
Deep Space Network (abreviated)
tonyrice
0
210
Faster Mobile Websites
deanohume
310
31k
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 を書いて動かしてみよう