CSS Preprocessors. Comparing SASS, LESS and Stylus

CSS Preprocessors
Sass, Less and Stylus
Patrick Arlt - @patrickarlt
Some Background
I'm an Designer and Developers at Geoloqi Esri.
Design, UX, HTML, CSS, JS, lots of it everyday...
Ok Ok, which is best?
Really Short Answer
SASS or Stylus
Slightly Longer Answer
SASS if you are using Ruby. Stylus if you using Node. LESS if
you afraid of the command line.
80/20
80% of SASS, LESS and Stylus is the same.
The 20% that is different is in advanced usage.
Installing
SASS
LESS
Stylus
$ gem install sass
$ sass --watch style.scss:style.css
<link rel="stylesheet/less" type="text/css" href="styles.less">
<script src="less.js" type="text/javascript"></script>
$ npm install less
$ lessc styles.less
$ npm install stylus
$ stylus css --watch
The 80%
Variables
Color Transformation
Mixins
Nesting
Loops & Conditionals
Importing
Variables
SASS
LESS
Stylus
$button-background: #27adec;
.btn {
background: $button-background;
}
@button-background: #27adec;
.btn {
background: @button-background;
}
button-background = #27adec
.btn
background button-background
Color Transformations
SASS
LESS
Stylus
lighten(@color, 10%);
mix($dark-blue, $light-blue, 25%);
body
color: #444 + #111;
Without Params With Params
LESS Mixins
.bordered {
border: 1px solid #000;
border-top-color: #444;
border-bottom-color: #444;
}
#main {
.bordered;
}
.border-radius (@r) {
-webkit-border-radius: @r;
-moz-border-radius: @r;
border-radius: @r;
}
#main {
.border-radius(4px);
}
SASS Mixins
@mixin border-radius ($radius: 5px) {
-webkit-border-radius: $radius;
-moz-border-radius: $radius;
border-radius: $radius;
}
#main {
@include border-radius(4px);
}
Stylus Mixins
border-radius(n)
-webkit-border-radius n
-moz-border-radius n
border-radius n
#main
border-radius(5px)
Nesting
You can nest selectors in all three frameworks.
#main{
margin: 0 auto;
.title {
font-size: 4em;
}
a {
text-decoration: none;
&:hover {
text-decoration: underline;
}
}
}
Imports
All 3 support importing from other files or libraries...
@import "compass/css3";
@import "susy";
@import "animation/animate";
@import "myfile.scss";
#main {
@include border-radius(5px); // from compass/css3
@include span-columns(10); // from susy
@include animation(fadeIn); // from animation/animate
background: $background-color; // from myfile.scss
}
#sidebar {
@include span-columns(2 omega); // from susy
}
More Features
Conditionals like "if, "when"
MATH!
SASS and Stylus
Loops like "for", "while", and "each"
Much more depth then LESS
Custom functions without the Ruby/JS API
The 20%
SASS
@extend
@media
@content
@extend
.button {
background: $blue;
color: #fff
}
.my-special-button {
@extend .button;
font-size: 2em;
}
.button, .my-special-button {
background: $blue;
color: #fff
}
.my-special-button {
font-size: 2em;
}
@extend Selectors
// This won't be compiled
#context a%extreme {
color: red;
font-weight: bold;
font-size: 2em;
}
.notice {
@extend %extreme;
}
#content a.notice {
color: $red;
font-weight: bold;
font-size: 2em;
}
@media
Declare media queries inside selectors
#content {
width: 65%;
margin: 0 auto;
@media only screen and (max-width : 767px) {
width: 90%;
}
}
#content {
width: 65%;
margin: 0 auto;
}
@media only screen and (max-device-width : 768px) {
#content {
width: 90%;
}
}
@content
My favorite SASS feature. Lets you pass whole style blocks
into mixins. Similar to Rubys "yeild". Use it for...
Media Query Helpers
Retina Images
IE Specific Styles
CSS3 Polyfills
@content Example
<!--[if IE 7 ]><html class="ie ie7" lang="en"><![endif]-->
<!--[if IE 8 ]><html class="ie ie8" lang="en"><![endif]-->
<!--[if (gte IE 9)|!(IE)]><!--><html lang="en"><!--<![endif]-->
@mixin for-ie(){
html.ie &{
@content;
}
}
#browser-warning {
display:none;
@include for-ie(){
display:block
}
}
Compass
makes SASS even more awesome
CSS3 mixins, supports almost every CSS3 feature
Typography styling helpers
Generates CSS sprites
Produces cross browser CSS for IE6,7,8
Plugin framework via Rubygems
Compass
Compass Bootstrap
Foundation Framework
Susy - Responsive Grids
Compass Animation
LESS
Mixins
Namespaces
Scoped Variables
Client Side Processing
Mixins
In LESS every class is a mixin
.clearfix() {
zoom: 1;
&:before { content: ''; display: block; }
&:after { content: ''; display: table; clear: both; }
}
#content {
.clearfix();
}
Namespaceing Mixins
Organize your mixins into namespaces
#my-framework {
.button () {
display: block;
border: 1px solid @dark-blue;
background-color: @blue;
color: @light-blue;
}
}
.a-button {
#my-framework > .button;
}
Scoped Variables
Variables have scope which makes them it easy to override
@text-color: #444;
@background-color: #fafafa;
body {
color: @text-color;
background: @background-color;
}
.inverse {
@text-color: #fafafa;
@background-color: #444;
color: @text-color;
background: @background-color;
}
h1 { color: @text-color + #111; }
Client-Side Compiling
Great for static HTML sites
Sites where you don't have a real server (S3)
You can evaluate Javascript in your .less files
Evalute Javascipt
You can evalute a javascript expression as a variable
@height: `document.body.clientHeight`;
@width: `document.body.clientWidth`;
Stylus
Syntax
Language Features
@keyframes
Javascript API
Stylus Syntax
Whitespace Based
Can omit { : ; }
The biggest problem I have with Stylus is with its syntax
border-radius()
-webkit-border-radius arguments
-moz-border-radius arguments
border-radius arguments
body
font 12px Helvetica, Arial, sans-serif
a.button
border-radius(5px)
Stylus Language
Stylus feels very much like a simple programming language
Ruby-like ranges [1..5], [0...5]
for/in loops
real operator precidence
complex conditionals if/else if/else, unless/else, postfix
conditionals
@keyframe Support
CSS3 keyframes are awesome, Stylus makes then easy
This is awesome!
@keyframes pulse
0%, 100%
-webkit-transform translateX(0);
20%, 60%
-webkit-transform translateX(-10px);
40%, 80%
-webkit-transform translateX(10px);
Javascript API
You could do a whole talk on the Stylus API, here are some
ideas...
Declare really custom functions
Use Node modules like canvas
Do Compass-like sprite generation
Create your own CSS framework
Nib
CSS3 helpers - gradiants, border-radius, ect...
Mixins for common css patterns
Extends CSS with new properties and values
#feedback
fixed: bottom right
#logo
image: '/img/logo.png'
h1
overflow: ellipsis
Smackdown!
Who Wins?
LESS Looses
LESS just doesn't have the features or power of SASS or
Stylus
Nothing like Compass or Nib
No plugin system
Can't define your own functions with just LESS
Doesn't output any debugging info
SASS vs. Stylus
Both have similar features, a powerful plugin ecosystem,
and lots of CSS3 helpers.
SASS syntax is close to CSS
Stylus is closer to a programming language
If you use Ruby you will probally use SASS
If you use Node you will probally use Stylus
Questions
Patrick Arlt - @patrickarlt
CSS Preprocessors. Comparing SASS, LESS and Stylus
1 of 38

Recommended

An Introduction to CSS Preprocessors (SASS & LESS) by
An Introduction to CSS Preprocessors (SASS & LESS)An Introduction to CSS Preprocessors (SASS & LESS)
An Introduction to CSS Preprocessors (SASS & LESS)Folio3 Software
1.6K views51 slides
LESS vs. SASS - CSS Precompiler Showdown by
LESS vs. SASS - CSS Precompiler ShowdownLESS vs. SASS - CSS Precompiler Showdown
LESS vs. SASS - CSS Precompiler ShowdownKevin Powell
11.2K views75 slides
5 fifth lesson -xml by
5 fifth lesson -xml5 fifth lesson -xml
5 fifth lesson -xmlMohammad Alyan
794 views19 slides
다른 회사는 어떻게 QA, 테스팅을 하고 있을까? (google, facebook, atlass... by
다른 회사는 어떻게 QA, 테스팅을 하고 있을까? (google, facebook, atlass...다른 회사는 어떻게 QA, 테스팅을 하고 있을까? (google, facebook, atlass...
다른 회사는 어떻게 QA, 테스팅을 하고 있을까? (google, facebook, atlass...Joseph Yonggoo Yeo
6.2K views8 slides
Start using less css by
Start using less cssStart using less css
Start using less cssAli MasudianPour
2.9K views13 slides
CSS Preprocessors with an introduction to LESS/SASS by
CSS Preprocessors with an introduction to LESS/SASSCSS Preprocessors with an introduction to LESS/SASS
CSS Preprocessors with an introduction to LESS/SASSvisual28
700 views39 slides

More Related Content

Viewers also liked

jQuery UI (Effect) by
jQuery UI (Effect) jQuery UI (Effect)
jQuery UI (Effect) anees abu-hmaid
3.2K views54 slides
باللغة العربية jQuery دورة by
 باللغة العربية jQuery دورة باللغة العربية jQuery دورة
باللغة العربية jQuery دورةanees abu-hmaid
4.4K views114 slides
Canvas دورة باللغة العربية by
Canvas دورة باللغة العربيةCanvas دورة باللغة العربية
Canvas دورة باللغة العربيةanees abu-hmaid
6.1K views115 slides
java script course دورة جافا سكربت باللغة العربية by
java script course دورة جافا سكربت باللغة العربيةjava script course دورة جافا سكربت باللغة العربية
java script course دورة جافا سكربت باللغة العربيةanees abu-hmaid
23.6K views290 slides
باللغة العربية SASS دورة by
  باللغة العربية SASS دورة   باللغة العربية SASS دورة
باللغة العربية SASS دورة anees abu-hmaid
8.4K views86 slides
باللغة العربية JSON دورة by
  باللغة العربية JSON دورة   باللغة العربية JSON دورة
باللغة العربية JSON دورة anees abu-hmaid
6.6K views40 slides

Viewers also liked(19)

باللغة العربية jQuery دورة by anees abu-hmaid
 باللغة العربية jQuery دورة باللغة العربية jQuery دورة
باللغة العربية jQuery دورة
anees abu-hmaid4.4K views
Canvas دورة باللغة العربية by anees abu-hmaid
Canvas دورة باللغة العربيةCanvas دورة باللغة العربية
Canvas دورة باللغة العربية
anees abu-hmaid6.1K views
java script course دورة جافا سكربت باللغة العربية by anees abu-hmaid
java script course دورة جافا سكربت باللغة العربيةjava script course دورة جافا سكربت باللغة العربية
java script course دورة جافا سكربت باللغة العربية
anees abu-hmaid23.6K views
باللغة العربية SASS دورة by anees abu-hmaid
  باللغة العربية SASS دورة   باللغة العربية SASS دورة
باللغة العربية SASS دورة
anees abu-hmaid8.4K views
باللغة العربية JSON دورة by anees abu-hmaid
  باللغة العربية JSON دورة   باللغة العربية JSON دورة
باللغة العربية JSON دورة
anees abu-hmaid6.6K views
Bootstrap3 دورة باللغة العربية by anees abu-hmaid
Bootstrap3 دورة باللغة العربيةBootstrap3 دورة باللغة العربية
Bootstrap3 دورة باللغة العربية
anees abu-hmaid15.8K views
Ecmascript 6 (ES6) جافا سكربت (6) by anees abu-hmaid
Ecmascript 6 (ES6) جافا سكربت (6)Ecmascript 6 (ES6) جافا سكربت (6)
Ecmascript 6 (ES6) جافا سكربت (6)
anees abu-hmaid7.3K views
구문과 의미론(정적 의미론까지) by Nam Hyeonuk
구문과 의미론(정적 의미론까지)구문과 의미론(정적 의미론까지)
구문과 의미론(정적 의미론까지)
Nam Hyeonuk14.8K views
دورة CSS3 باللغة العربية by anees abu-hmaid
دورة CSS3 باللغة العربيةدورة CSS3 باللغة العربية
دورة CSS3 باللغة العربية
anees abu-hmaid6.4K views
Intro to css & sass by Sean Wolfe
Intro to css & sassIntro to css & sass
Intro to css & sass
Sean Wolfe3K views
Sass - Getting Started with Sass! by Eric Sembrat
Sass - Getting Started with Sass!Sass - Getting Started with Sass!
Sass - Getting Started with Sass!
Eric Sembrat8K views
Sass and compass workshop by Shaho Toofani
Sass and compass workshopSass and compass workshop
Sass and compass workshop
Shaho Toofani982 views
게임 스타트업 시작하기 by 기룡 남
게임 스타트업 시작하기게임 스타트업 시작하기
게임 스타트업 시작하기
기룡 남23.4K views
[D2]thread dump 분석기법과 사례 by NAVER D2
[D2]thread dump 분석기법과 사례[D2]thread dump 분석기법과 사례
[D2]thread dump 분석기법과 사례
NAVER D213.1K views
[D2]pinpoint 개발기 by NAVER D2
[D2]pinpoint 개발기[D2]pinpoint 개발기
[D2]pinpoint 개발기
NAVER D213.3K views

Recently uploaded

PharoJS - Zürich Smalltalk Group Meetup November 2023 by
PharoJS - Zürich Smalltalk Group Meetup November 2023PharoJS - Zürich Smalltalk Group Meetup November 2023
PharoJS - Zürich Smalltalk Group Meetup November 2023Noury Bouraqadi
127 views17 slides
Scaling Knowledge Graph Architectures with AI by
Scaling Knowledge Graph Architectures with AIScaling Knowledge Graph Architectures with AI
Scaling Knowledge Graph Architectures with AIEnterprise Knowledge
30 views15 slides
Five Things You SHOULD Know About Postman by
Five Things You SHOULD Know About PostmanFive Things You SHOULD Know About Postman
Five Things You SHOULD Know About PostmanPostman
33 views43 slides
iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas... by
iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas...iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas...
iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas...Bernd Ruecker
37 views69 slides
Network Source of Truth and Infrastructure as Code revisited by
Network Source of Truth and Infrastructure as Code revisitedNetwork Source of Truth and Infrastructure as Code revisited
Network Source of Truth and Infrastructure as Code revisitedNetwork Automation Forum
26 views45 slides
SUPPLIER SOURCING.pptx by
SUPPLIER SOURCING.pptxSUPPLIER SOURCING.pptx
SUPPLIER SOURCING.pptxangelicacueva6
15 views1 slide

Recently uploaded(20)

PharoJS - Zürich Smalltalk Group Meetup November 2023 by Noury Bouraqadi
PharoJS - Zürich Smalltalk Group Meetup November 2023PharoJS - Zürich Smalltalk Group Meetup November 2023
PharoJS - Zürich Smalltalk Group Meetup November 2023
Noury Bouraqadi127 views
Five Things You SHOULD Know About Postman by Postman
Five Things You SHOULD Know About PostmanFive Things You SHOULD Know About Postman
Five Things You SHOULD Know About Postman
Postman33 views
iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas... by Bernd Ruecker
iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas...iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas...
iSAQB Software Architecture Gathering 2023: How Process Orchestration Increas...
Bernd Ruecker37 views
Case Study Copenhagen Energy and Business Central.pdf by Aitana
Case Study Copenhagen Energy and Business Central.pdfCase Study Copenhagen Energy and Business Central.pdf
Case Study Copenhagen Energy and Business Central.pdf
Aitana16 views
HTTP headers that make your website go faster - devs.gent November 2023 by Thijs Feryn
HTTP headers that make your website go faster - devs.gent November 2023HTTP headers that make your website go faster - devs.gent November 2023
HTTP headers that make your website go faster - devs.gent November 2023
Thijs Feryn22 views
Igniting Next Level Productivity with AI-Infused Data Integration Workflows by Safe Software
Igniting Next Level Productivity with AI-Infused Data Integration Workflows Igniting Next Level Productivity with AI-Infused Data Integration Workflows
Igniting Next Level Productivity with AI-Infused Data Integration Workflows
Safe Software263 views
handbook for web 3 adoption.pdf by Liveplex
handbook for web 3 adoption.pdfhandbook for web 3 adoption.pdf
handbook for web 3 adoption.pdf
Liveplex22 views
STKI Israeli Market Study 2023 corrected forecast 2023_24 v3.pdf by Dr. Jimmy Schwarzkopf
STKI Israeli Market Study 2023   corrected forecast 2023_24 v3.pdfSTKI Israeli Market Study 2023   corrected forecast 2023_24 v3.pdf
STKI Israeli Market Study 2023 corrected forecast 2023_24 v3.pdf
Data Integrity for Banking and Financial Services by Precisely
Data Integrity for Banking and Financial ServicesData Integrity for Banking and Financial Services
Data Integrity for Banking and Financial Services
Precisely21 views
Attacking IoT Devices from a Web Perspective - Linux Day by Simone Onofri
Attacking IoT Devices from a Web Perspective - Linux Day Attacking IoT Devices from a Web Perspective - Linux Day
Attacking IoT Devices from a Web Perspective - Linux Day
Simone Onofri16 views
【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院 by IttrainingIttraining
【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院
【USB韌體設計課程】精選講義節錄-USB的列舉過程_艾鍗學院

CSS Preprocessors. Comparing SASS, LESS and Stylus

  • 1. CSS Preprocessors Sass, Less and Stylus Patrick Arlt - @patrickarlt
  • 2. Some Background I'm an Designer and Developers at Geoloqi Esri. Design, UX, HTML, CSS, JS, lots of it everyday...
  • 3. Ok Ok, which is best? Really Short Answer SASS or Stylus Slightly Longer Answer SASS if you are using Ruby. Stylus if you using Node. LESS if you afraid of the command line.
  • 4. 80/20 80% of SASS, LESS and Stylus is the same. The 20% that is different is in advanced usage.
  • 5. Installing SASS LESS Stylus $ gem install sass $ sass --watch style.scss:style.css <link rel="stylesheet/less" type="text/css" href="styles.less"> <script src="less.js" type="text/javascript"></script> $ npm install less $ lessc styles.less $ npm install stylus $ stylus css --watch
  • 7. Variables SASS LESS Stylus $button-background: #27adec; .btn { background: $button-background; } @button-background: #27adec; .btn { background: @button-background; } button-background = #27adec .btn background button-background
  • 9. Without Params With Params LESS Mixins .bordered { border: 1px solid #000; border-top-color: #444; border-bottom-color: #444; } #main { .bordered; } .border-radius (@r) { -webkit-border-radius: @r; -moz-border-radius: @r; border-radius: @r; } #main { .border-radius(4px); }
  • 10. SASS Mixins @mixin border-radius ($radius: 5px) { -webkit-border-radius: $radius; -moz-border-radius: $radius; border-radius: $radius; } #main { @include border-radius(4px); }
  • 12. Nesting You can nest selectors in all three frameworks. #main{ margin: 0 auto; .title { font-size: 4em; } a { text-decoration: none; &:hover { text-decoration: underline; } } }
  • 13. Imports All 3 support importing from other files or libraries... @import "compass/css3"; @import "susy"; @import "animation/animate"; @import "myfile.scss"; #main { @include border-radius(5px); // from compass/css3 @include span-columns(10); // from susy @include animation(fadeIn); // from animation/animate background: $background-color; // from myfile.scss } #sidebar { @include span-columns(2 omega); // from susy }
  • 14. More Features Conditionals like "if, "when" MATH! SASS and Stylus Loops like "for", "while", and "each" Much more depth then LESS Custom functions without the Ruby/JS API
  • 17. @extend .button { background: $blue; color: #fff } .my-special-button { @extend .button; font-size: 2em; } .button, .my-special-button { background: $blue; color: #fff } .my-special-button { font-size: 2em; }
  • 18. @extend Selectors // This won't be compiled #context a%extreme { color: red; font-weight: bold; font-size: 2em; } .notice { @extend %extreme; } #content a.notice { color: $red; font-weight: bold; font-size: 2em; }
  • 19. @media Declare media queries inside selectors #content { width: 65%; margin: 0 auto; @media only screen and (max-width : 767px) { width: 90%; } } #content { width: 65%; margin: 0 auto; } @media only screen and (max-device-width : 768px) { #content { width: 90%; } }
  • 20. @content My favorite SASS feature. Lets you pass whole style blocks into mixins. Similar to Rubys "yeild". Use it for... Media Query Helpers Retina Images IE Specific Styles CSS3 Polyfills
  • 21. @content Example <!--[if IE 7 ]><html class="ie ie7" lang="en"><![endif]--> <!--[if IE 8 ]><html class="ie ie8" lang="en"><![endif]--> <!--[if (gte IE 9)|!(IE)]><!--><html lang="en"><!--<![endif]--> @mixin for-ie(){ html.ie &{ @content; } } #browser-warning { display:none; @include for-ie(){ display:block } }
  • 22. Compass makes SASS even more awesome CSS3 mixins, supports almost every CSS3 feature Typography styling helpers Generates CSS sprites Produces cross browser CSS for IE6,7,8 Plugin framework via Rubygems Compass Compass Bootstrap Foundation Framework Susy - Responsive Grids Compass Animation
  • 24. Mixins In LESS every class is a mixin .clearfix() { zoom: 1; &:before { content: ''; display: block; } &:after { content: ''; display: table; clear: both; } } #content { .clearfix(); }
  • 25. Namespaceing Mixins Organize your mixins into namespaces #my-framework { .button () { display: block; border: 1px solid @dark-blue; background-color: @blue; color: @light-blue; } } .a-button { #my-framework > .button; }
  • 26. Scoped Variables Variables have scope which makes them it easy to override @text-color: #444; @background-color: #fafafa; body { color: @text-color; background: @background-color; } .inverse { @text-color: #fafafa; @background-color: #444; color: @text-color; background: @background-color; } h1 { color: @text-color + #111; }
  • 27. Client-Side Compiling Great for static HTML sites Sites where you don't have a real server (S3) You can evaluate Javascript in your .less files Evalute Javascipt You can evalute a javascript expression as a variable @height: `document.body.clientHeight`; @width: `document.body.clientWidth`;
  • 29. Stylus Syntax Whitespace Based Can omit { : ; } The biggest problem I have with Stylus is with its syntax border-radius() -webkit-border-radius arguments -moz-border-radius arguments border-radius arguments body font 12px Helvetica, Arial, sans-serif a.button border-radius(5px)
  • 30. Stylus Language Stylus feels very much like a simple programming language Ruby-like ranges [1..5], [0...5] for/in loops real operator precidence complex conditionals if/else if/else, unless/else, postfix conditionals
  • 31. @keyframe Support CSS3 keyframes are awesome, Stylus makes then easy This is awesome! @keyframes pulse 0%, 100% -webkit-transform translateX(0); 20%, 60% -webkit-transform translateX(-10px); 40%, 80% -webkit-transform translateX(10px);
  • 32. Javascript API You could do a whole talk on the Stylus API, here are some ideas... Declare really custom functions Use Node modules like canvas Do Compass-like sprite generation Create your own CSS framework
  • 33. Nib CSS3 helpers - gradiants, border-radius, ect... Mixins for common css patterns Extends CSS with new properties and values #feedback fixed: bottom right #logo image: '/img/logo.png' h1 overflow: ellipsis
  • 35. LESS Looses LESS just doesn't have the features or power of SASS or Stylus Nothing like Compass or Nib No plugin system Can't define your own functions with just LESS Doesn't output any debugging info
  • 36. SASS vs. Stylus Both have similar features, a powerful plugin ecosystem, and lots of CSS3 helpers. SASS syntax is close to CSS Stylus is closer to a programming language If you use Ruby you will probally use SASS If you use Node you will probally use Stylus
  • 37. Questions Patrick Arlt - @patrickarlt