SlideShare una empresa de Scribd logo
1 de 35
Descargar para leer sin conexión
CSS with superpowers ― 
SASS! 
Ferdinand Vogler 
@ferdinandvogler
Ferdinand Vogler 
@ferdinandvogler 
Communication Design student, 
Working student at YOU IS NOW, 
Freelance Designer and Web-Developer
OpenTechSchool 
opentechschool.org 
Berlin, Brussels, Dortmund, Hamburg, Istanbul, Jerusalem, London, 
Melbourne, Nairobi, Ramallah, RheinMain, Stockholm, San Francisco, Tel- 
Aviv, Washington, Zürich
“If you really want to learn how to do something, try 
teaching other people how to do it.” 
– Steve Krug, Rocket Surgery Made Easy
Why SASS?
1996 
First W3C recommendation (CSS1)
2014
Preprocessors
Advantages 
❏ Variables 
❏ Nesting 
❏ Reusable blocks 
❏ Fewer HTTP requests 
❏ Conditionals, Loops & Functions 
❏ Mathematics 
Don’t Repeat Yourself
How does it work? 
style.scss Preprocessor style.css
style.css 
scss 
a { 
color: gray; 
} 
a:hover { 
color: black; 
font-weight: bold; 
} 
p { 
margin: 10px; 
}
“Later, when you’ve become fluent with Sass 
[…], it really does feel like a natural extension 
of CSS — as if it’s filling holes we all wish 
were filled by the CSS spec itself.” 
Dan Cederholm in alistapart.com/article/why-sass
ಠ_ಠ
Nope.
SASS? 
SCSS? 
?
style.scss style.sass 
@mixin border-radius($radius) { 
-webkit-border-radius: $radius; 
-moz-border-radius: $radius; 
-ms-border-radius: $radius; 
border-radius: $radius; 
} 
#main { 
background: gray; 
width: 50%; 
@include border-radius(4px); 
p { 
background: lightgray; 
color: black; 
} 
} 
=border-radius($radius) 
––-webkit-border-radius: $radius 
––-moz-border-radius: $radius 
––-ms-border-radius: $radius 
––border-radius: $radius 
#main 
––background: gray 
––width: 50% 
––+border-radius(4px) 
––p 
––––background: lightgray 
––––color: black
Install SASS
Ruby Gems 
Mac 
Open Terminal: ruby -v 
Windows 
Install from www.rubyinstaller.org
Installation 
Mac 
sudo gem install sass 
Windows 
gem install sass
Apps 
CodeKit 
Prepros 
Scout 
Koala 
Compass 
Hammer 
Mixture 
LiveReload 
…
<> 
Live-Coding 
Basic Terminal usage
Commands 
cd Change directory 
cd .. Go back one directory 
cd ~ Go to Home 
ls List directory 
touch Create file 
rm Remove file 
mkdir Make directory 
rmdir Remove directory
<> 
Live-Coding 
SASS in the command line
Basic SASS commands 
sass input.scss output.css Compile once 
sass --watch input.scss:output.css Watch file 
sass --watch scss:css Watch folder
Partials 
|stylesheets 
|--style.css 
/* Buttons */ 
/* Panels */ 
/* Lists */ 
CSS
Partials 
|stylesheets 
|--partials 
|------_buttons.scss 
|------_panels.scss 
|------_lists.scss 
|--vendor 
|----_normalize.scss 
|--style.scss 
@import “partials/buttons”; 
@import “partials/panels”; 
@import “partials/lists”; 
// Third-party stylesheets 
@import “vendor/normalize”; 
SCSS 
style.css
<> 
Live-Coding 
SASS playground
Variables 
$color = red; 
$darkercolor = darken($color, 25%); 
$lightercolor = lighten($color, 15%); 
adjust-hue(); 
saturate(); 
mix(); 
grayscale(); 
desaturate(); 
invert(); 
complement();
Nesting 
.my-style { 
.highlight { 
a { 
&:hover { 
} 
} 
} 
}
Fewer HTTP requests 
|stylesheets 
|--partials 
|------_buttons.scss 
|------_panels.scss 
|------_lists.scss 
|--vendor 
|----_normalize.scss 
|--style.scss 
style.css
Conditionals, Loops & Functions 
@function sample($var1, $var2) { 
… } 
@for $i from 1 through 10 { 
… } 
@mixin block($var1) { 
@if $var1 == large { 
… } 
}
Scratching the surface
Further information 
❏ www.thesassway.com 
❏ www.sass-lang.com 
❏ www.leveluptuts.com/tutorials/sass-tutorials 
❏ Dan Cederholm – “SASS for Web-Designers” 
❏ www.sassmeister.com
Questions? Feedback? 
@ferdinandvogler

Más contenido relacionado

Destacado

Emotion reading of siren tech
Emotion reading of siren techEmotion reading of siren tech
Emotion reading of siren techsimonuestc
 
ZOO PATRYK
ZOO PATRYKZOO PATRYK
ZOO PATRYKklasa6
 
Oportunidades en biotecnología 2014
Oportunidades en biotecnología 2014Oportunidades en biotecnología 2014
Oportunidades en biotecnología 2014Manager Asesores
 
ThanksGiving
ThanksGivingThanksGiving
ThanksGivingmattmcna
 
Pest analizi
Pest analiziPest analizi
Pest analizisafiye26
 
You're losing money, and don't even know it: How to maximize your law firm ga...
You're losing money, and don't even know it: How to maximize your law firm ga...You're losing money, and don't even know it: How to maximize your law firm ga...
You're losing money, and don't even know it: How to maximize your law firm ga...CaseGhost
 
Proyecto vocacional 2012 2014
Proyecto vocacional 2012 2014Proyecto vocacional 2012 2014
Proyecto vocacional 2012 2014franfrater
 

Destacado (13)

Soc12
Soc12Soc12
Soc12
 
Comandos huawei-prof
Comandos huawei-profComandos huawei-prof
Comandos huawei-prof
 
Catalogo 2015 baja
Catalogo 2015 bajaCatalogo 2015 baja
Catalogo 2015 baja
 
Emotion reading of siren tech
Emotion reading of siren techEmotion reading of siren tech
Emotion reading of siren tech
 
ZOO PATRYK
ZOO PATRYKZOO PATRYK
ZOO PATRYK
 
Behaviour As Predictor of Dementia
Behaviour As Predictor of DementiaBehaviour As Predictor of Dementia
Behaviour As Predictor of Dementia
 
Oportunidades en biotecnología 2014
Oportunidades en biotecnología 2014Oportunidades en biotecnología 2014
Oportunidades en biotecnología 2014
 
ThanksGiving
ThanksGivingThanksGiving
ThanksGiving
 
EPM Top Trends 2016
EPM Top Trends 2016EPM Top Trends 2016
EPM Top Trends 2016
 
Titles and credits
Titles and creditsTitles and credits
Titles and credits
 
Pest analizi
Pest analiziPest analizi
Pest analizi
 
You're losing money, and don't even know it: How to maximize your law firm ga...
You're losing money, and don't even know it: How to maximize your law firm ga...You're losing money, and don't even know it: How to maximize your law firm ga...
You're losing money, and don't even know it: How to maximize your law firm ga...
 
Proyecto vocacional 2012 2014
Proyecto vocacional 2012 2014Proyecto vocacional 2012 2014
Proyecto vocacional 2012 2014
 

Similar a CSS with superpowers - SASS!

Dallas Drupal Days 2012 - Introduction to less sass-compass
Dallas Drupal Days 2012  - Introduction to less sass-compassDallas Drupal Days 2012  - Introduction to less sass-compass
Dallas Drupal Days 2012 - Introduction to less sass-compassChris Lee
 
Intro to Sass for WordPress Developers
Intro to Sass for WordPress DevelopersIntro to Sass for WordPress Developers
Intro to Sass for WordPress DevelopersSuzette Franck
 
SCSS Implementation
SCSS ImplementationSCSS Implementation
SCSS ImplementationAmey Parab
 
An Introduction to CSS Frameworks
An Introduction to CSS FrameworksAn Introduction to CSS Frameworks
An Introduction to CSS FrameworksAdrian Westlake
 
The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}
The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}
The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}Eric Carlisle
 
BDUG Responsive Web Theming - 7/23/12
BDUG Responsive Web Theming - 7/23/12BDUG Responsive Web Theming - 7/23/12
BDUG Responsive Web Theming - 7/23/12ucbdrupal
 
How to Use the Command Line to Increase Speed of Development
How to Use the Command Line to Increase Speed of DevelopmentHow to Use the Command Line to Increase Speed of Development
How to Use the Command Line to Increase Speed of DevelopmentAcquia
 
Not Just a Pretty Face: How to design and build a cross-CMS CSS framework
Not Just a Pretty Face: How to design and build a cross-CMS CSS frameworkNot Just a Pretty Face: How to design and build a cross-CMS CSS framework
Not Just a Pretty Face: How to design and build a cross-CMS CSS frameworkcrystalenka
 
960 grid psd
960 grid psd960 grid psd
960 grid psdRaju Nag
 
Hardboiled Front End Development — Found.ation
Hardboiled Front End Development — Found.ationHardboiled Front End Development — Found.ation
Hardboiled Front End Development — Found.ationSpiros Martzoukos
 
CSS framework By Palash
CSS framework By PalashCSS framework By Palash
CSS framework By PalashPalashBajpai
 
Web Summer Camp Keynote
Web Summer Camp KeynoteWeb Summer Camp Keynote
Web Summer Camp KeynoteRachel Andrew
 
Elegant CSS Design In Drupal: LESS vs Sass
Elegant CSS Design In Drupal: LESS vs SassElegant CSS Design In Drupal: LESS vs Sass
Elegant CSS Design In Drupal: LESS vs SassMediacurrent
 
Authoring Stylesheets with Compass & Sass
Authoring Stylesheets with Compass & SassAuthoring Stylesheets with Compass & Sass
Authoring Stylesheets with Compass & Sasschriseppstein
 

Similar a CSS with superpowers - SASS! (20)

Dallas Drupal Days 2012 - Introduction to less sass-compass
Dallas Drupal Days 2012  - Introduction to less sass-compassDallas Drupal Days 2012  - Introduction to less sass-compass
Dallas Drupal Days 2012 - Introduction to less sass-compass
 
Intro to Sass for WordPress Developers
Intro to Sass for WordPress DevelopersIntro to Sass for WordPress Developers
Intro to Sass for WordPress Developers
 
SCSS Implementation
SCSS ImplementationSCSS Implementation
SCSS Implementation
 
An Introduction to CSS Frameworks
An Introduction to CSS FrameworksAn Introduction to CSS Frameworks
An Introduction to CSS Frameworks
 
UNIT 3.ppt
UNIT 3.pptUNIT 3.ppt
UNIT 3.ppt
 
SAS X
SAS XSAS X
SAS X
 
The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}
The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}
The New UI - Staying Strong with Flexbox, SASS, and {{Mustache.js}}
 
BDUG Responsive Web Theming - 7/23/12
BDUG Responsive Web Theming - 7/23/12BDUG Responsive Web Theming - 7/23/12
BDUG Responsive Web Theming - 7/23/12
 
How to Use the Command Line to Increase Speed of Development
How to Use the Command Line to Increase Speed of DevelopmentHow to Use the Command Line to Increase Speed of Development
How to Use the Command Line to Increase Speed of Development
 
Not Just a Pretty Face: How to design and build a cross-CMS CSS framework
Not Just a Pretty Face: How to design and build a cross-CMS CSS frameworkNot Just a Pretty Face: How to design and build a cross-CMS CSS framework
Not Just a Pretty Face: How to design and build a cross-CMS CSS framework
 
Knowing it all
Knowing it allKnowing it all
Knowing it all
 
960 grid psd
960 grid psd960 grid psd
960 grid psd
 
Using a CSS Framework
Using a CSS FrameworkUsing a CSS Framework
Using a CSS Framework
 
Hardboiled Front End Development — Found.ation
Hardboiled Front End Development — Found.ationHardboiled Front End Development — Found.ation
Hardboiled Front End Development — Found.ation
 
Death of a Themer
Death of a ThemerDeath of a Themer
Death of a Themer
 
CSS framework By Palash
CSS framework By PalashCSS framework By Palash
CSS framework By Palash
 
Web Summer Camp Keynote
Web Summer Camp KeynoteWeb Summer Camp Keynote
Web Summer Camp Keynote
 
Elegant CSS Design In Drupal: LESS vs Sass
Elegant CSS Design In Drupal: LESS vs SassElegant CSS Design In Drupal: LESS vs Sass
Elegant CSS Design In Drupal: LESS vs Sass
 
Create a landing page
Create a landing pageCreate a landing page
Create a landing page
 
Authoring Stylesheets with Compass & Sass
Authoring Stylesheets with Compass & SassAuthoring Stylesheets with Compass & Sass
Authoring Stylesheets with Compass & Sass
 

Último

一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证
一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证
一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证wpkuukw
 
Minimalist Orange Portfolio by Slidesgo.pptx
Minimalist Orange Portfolio by Slidesgo.pptxMinimalist Orange Portfolio by Slidesgo.pptx
Minimalist Orange Portfolio by Slidesgo.pptxbalqisyamutia
 
cholilithiasis, cholecystitis,gall bladdder .pdf
cholilithiasis, cholecystitis,gall bladdder .pdfcholilithiasis, cholecystitis,gall bladdder .pdf
cholilithiasis, cholecystitis,gall bladdder .pdfRawalRafiqLeghari
 
Raebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for Friendship
Raebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for FriendshipRaebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for Friendship
Raebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for FriendshipNitya salvi
 
Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...gajnagarg
 
Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...
Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...
Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...HyderabadDolls
 
Q4-W4-SCIENCE-5 power point presentation
Q4-W4-SCIENCE-5 power point presentationQ4-W4-SCIENCE-5 power point presentation
Q4-W4-SCIENCE-5 power point presentationZenSeloveres
 
Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...
Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...
Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...Nitya salvi
 
Independent Escorts Goregaon WhatsApp +91-9930687706, Best Service
Independent Escorts Goregaon WhatsApp +91-9930687706, Best ServiceIndependent Escorts Goregaon WhatsApp +91-9930687706, Best Service
Independent Escorts Goregaon WhatsApp +91-9930687706, Best Servicemeghakumariji156
 
怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证
怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证
怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证eeanqy
 
Sweety Planet Packaging Design Process Book.pptx
Sweety Planet Packaging Design Process Book.pptxSweety Planet Packaging Design Process Book.pptx
Sweety Planet Packaging Design Process Book.pptxbingyichin04
 
Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...
Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...
Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...nirzagarg
 
Resume all my skills and educations and achievement
Resume all my skills and educations and  achievement Resume all my skills and educations and  achievement
Resume all my skills and educations and achievement 210303105569
 
How to Build a Simple Shopify Website
How to Build a Simple Shopify WebsiteHow to Build a Simple Shopify Website
How to Build a Simple Shopify Websitemark11275
 
Branding in the Psychedelic Landscape Report.pdf
Branding in the Psychedelic Landscape Report.pdfBranding in the Psychedelic Landscape Report.pdf
Branding in the Psychedelic Landscape Report.pdfAlexandra Plesner
 
Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...
Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...
Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...HyderabadDolls
 
Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...
Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...
Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...HyderabadDolls
 
Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...
Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...
Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...Nitya salvi
 
Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...
Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...
Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...manjugarg389
 

Último (20)

一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证
一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证
一比一定(购)卡尔顿大学毕业证(CU毕业证)成绩单学位证
 
Minimalist Orange Portfolio by Slidesgo.pptx
Minimalist Orange Portfolio by Slidesgo.pptxMinimalist Orange Portfolio by Slidesgo.pptx
Minimalist Orange Portfolio by Slidesgo.pptx
 
cholilithiasis, cholecystitis,gall bladdder .pdf
cholilithiasis, cholecystitis,gall bladdder .pdfcholilithiasis, cholecystitis,gall bladdder .pdf
cholilithiasis, cholecystitis,gall bladdder .pdf
 
Raebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for Friendship
Raebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for FriendshipRaebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for Friendship
Raebareli Girl Whatsapp Number 📞 8617370543 | Girls Number for Friendship
 
Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...
Top profile Call Girls In eluru [ 7014168258 ] Call Me For Genuine Models We ...
 
Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...
Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...
Aminabad * High Profile Escorts Service in Lucknow Phone No 9548273370 Elite ...
 
Q4-W4-SCIENCE-5 power point presentation
Q4-W4-SCIENCE-5 power point presentationQ4-W4-SCIENCE-5 power point presentation
Q4-W4-SCIENCE-5 power point presentation
 
Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...
Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...
Just Call Vip call girls Kasganj Escorts ☎️8617370543 Two shot with one girl ...
 
Independent Escorts Goregaon WhatsApp +91-9930687706, Best Service
Independent Escorts Goregaon WhatsApp +91-9930687706, Best ServiceIndependent Escorts Goregaon WhatsApp +91-9930687706, Best Service
Independent Escorts Goregaon WhatsApp +91-9930687706, Best Service
 
Abortion Pills in Oman (+918133066128) Cytotec clinic buy Oman Muscat
Abortion Pills in Oman (+918133066128) Cytotec clinic buy Oman MuscatAbortion Pills in Oman (+918133066128) Cytotec clinic buy Oman Muscat
Abortion Pills in Oman (+918133066128) Cytotec clinic buy Oman Muscat
 
怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证
怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证
怎样办理伯明翰大学学院毕业证(Birmingham毕业证书)成绩单留信认证
 
Sweety Planet Packaging Design Process Book.pptx
Sweety Planet Packaging Design Process Book.pptxSweety Planet Packaging Design Process Book.pptx
Sweety Planet Packaging Design Process Book.pptx
 
Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...
Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...
Top profile Call Girls In Mau [ 7014168258 ] Call Me For Genuine Models We ar...
 
Resume all my skills and educations and achievement
Resume all my skills and educations and  achievement Resume all my skills and educations and  achievement
Resume all my skills and educations and achievement
 
How to Build a Simple Shopify Website
How to Build a Simple Shopify WebsiteHow to Build a Simple Shopify Website
How to Build a Simple Shopify Website
 
Branding in the Psychedelic Landscape Report.pdf
Branding in the Psychedelic Landscape Report.pdfBranding in the Psychedelic Landscape Report.pdf
Branding in the Psychedelic Landscape Report.pdf
 
Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...
Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...
Nishatganj ? Book Call Girls in Lucknow | Book 9548273370 Extreme Naughty Cal...
 
Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...
Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...
Madhyamgram \ (Genuine) Escort Service Kolkata | Service-oriented sexy call g...
 
Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...
Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...
Call Girls In Ratnagiri Escorts ☎️8617370543 🔝 💃 Enjoy 24/7 Escort Service En...
 
Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...
Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...
Kondapur ] High Profile Call Girls in Hyderabad (Adult Only) 9352988975 Escor...
 

CSS with superpowers - SASS!

  • 1. CSS with superpowers ― SASS! Ferdinand Vogler @ferdinandvogler
  • 2. Ferdinand Vogler @ferdinandvogler Communication Design student, Working student at YOU IS NOW, Freelance Designer and Web-Developer
  • 3.
  • 4. OpenTechSchool opentechschool.org Berlin, Brussels, Dortmund, Hamburg, Istanbul, Jerusalem, London, Melbourne, Nairobi, Ramallah, RheinMain, Stockholm, San Francisco, Tel- Aviv, Washington, Zürich
  • 5. “If you really want to learn how to do something, try teaching other people how to do it.” – Steve Krug, Rocket Surgery Made Easy
  • 7. 1996 First W3C recommendation (CSS1)
  • 10. Advantages ❏ Variables ❏ Nesting ❏ Reusable blocks ❏ Fewer HTTP requests ❏ Conditionals, Loops & Functions ❏ Mathematics Don’t Repeat Yourself
  • 11. How does it work? style.scss Preprocessor style.css
  • 12. style.css scss a { color: gray; } a:hover { color: black; font-weight: bold; } p { margin: 10px; }
  • 13. “Later, when you’ve become fluent with Sass […], it really does feel like a natural extension of CSS — as if it’s filling holes we all wish were filled by the CSS spec itself.” Dan Cederholm in alistapart.com/article/why-sass
  • 15. Nope.
  • 17. style.scss style.sass @mixin border-radius($radius) { -webkit-border-radius: $radius; -moz-border-radius: $radius; -ms-border-radius: $radius; border-radius: $radius; } #main { background: gray; width: 50%; @include border-radius(4px); p { background: lightgray; color: black; } } =border-radius($radius) ––-webkit-border-radius: $radius ––-moz-border-radius: $radius ––-ms-border-radius: $radius ––border-radius: $radius #main ––background: gray ––width: 50% ––+border-radius(4px) ––p ––––background: lightgray ––––color: black
  • 19. Ruby Gems Mac Open Terminal: ruby -v Windows Install from www.rubyinstaller.org
  • 20. Installation Mac sudo gem install sass Windows gem install sass
  • 21. Apps CodeKit Prepros Scout Koala Compass Hammer Mixture LiveReload …
  • 22. <> Live-Coding Basic Terminal usage
  • 23. Commands cd Change directory cd .. Go back one directory cd ~ Go to Home ls List directory touch Create file rm Remove file mkdir Make directory rmdir Remove directory
  • 24. <> Live-Coding SASS in the command line
  • 25. Basic SASS commands sass input.scss output.css Compile once sass --watch input.scss:output.css Watch file sass --watch scss:css Watch folder
  • 26. Partials |stylesheets |--style.css /* Buttons */ /* Panels */ /* Lists */ CSS
  • 27. Partials |stylesheets |--partials |------_buttons.scss |------_panels.scss |------_lists.scss |--vendor |----_normalize.scss |--style.scss @import “partials/buttons”; @import “partials/panels”; @import “partials/lists”; // Third-party stylesheets @import “vendor/normalize”; SCSS style.css
  • 28. <> Live-Coding SASS playground
  • 29. Variables $color = red; $darkercolor = darken($color, 25%); $lightercolor = lighten($color, 15%); adjust-hue(); saturate(); mix(); grayscale(); desaturate(); invert(); complement();
  • 30. Nesting .my-style { .highlight { a { &:hover { } } } }
  • 31. Fewer HTTP requests |stylesheets |--partials |------_buttons.scss |------_panels.scss |------_lists.scss |--vendor |----_normalize.scss |--style.scss style.css
  • 32. Conditionals, Loops & Functions @function sample($var1, $var2) { … } @for $i from 1 through 10 { … } @mixin block($var1) { @if $var1 == large { … } }
  • 34. Further information ❏ www.thesassway.com ❏ www.sass-lang.com ❏ www.leveluptuts.com/tutorials/sass-tutorials ❏ Dan Cederholm – “SASS for Web-Designers” ❏ www.sassmeister.com