SlideShare une entreprise Scribd logo
1  sur  76
Télécharger pour lire hors ligne
Pre-processing
INCEPTION ALL OVER AGAIN!
RIP
ARJAN EISING
  He’s not really dead :)
Hi, I’m Kristof
@houbenkristof — kristof@treeshadow.be
Front-end/design
at Mobile Vikings
I’m always up for a
Challenge
Run a small firm
  CALLED TREESHADOW MEDIA
Creative Brewski
TOGETHER WITH @TOMCLAUS & @DENNISJANSSEN
LEt’s TALK

CSS
"You don’t need a new stylesheet
syntax, CSS is simple and you’re
   a moron if you can’t do it."
C’est très simple
Not that easy to
    maintain
Stylesheets evolve
Simplicity creates
   complexity
Keep things DRY
   DON’T REPEAT YOURSELF
we should
Reference to
  existing
information
"CSS is the weakest link in the web developers
toolbox. The problem goes deeper than CSS’s
   lack of variables. Unlike the “function” in
  programming, CSS has no fundamental
               building block."
It’s all about
Abstractions
CSS PRIMITIVES HAVE
    NO MEANING
That’s our job!
Abstractions
 ARE GROUPS OF PRIMITIVES
Abstractions are
not abstract to us
We give BUILDING
  BLOCKs meaning
SO IT MAKES IT EASIER FOR US TO UNDERSTAND
Our
DESIGNS
CHANGE
A kitten dies every
time that happens
Find & replace
OH PLEASE, DON’T GET ME STARTED!
Client: “We want #000 to be #333 but not
    the user information underneath my
  #bada55 body text, oh while you're at it
could you position absolute that element and
       rotate it a gazillion degrees, …

 oh, #333 doesn't look that great after all…

             Change it back!”
You’re screwed
What do we
NEED?
The interior
 decorator!
Decorates with
    parts
He does not make
   those parts
   LAMPS, TABLES, CHAIRS…
PArts for




  PArts
Oh my god
YOU REUSED A BUTTON!
When elements are common


REUSE tHEM!
Focus!
ON WHAT IS IMPORTANT,
YOU MUST!
Hard to upgrade
 Customized third
party stylesheets
Clearly we are in
   need of some
 Pre-processing
"In computer science, a preprocessor is a
program that processes its input data to
           produce output that
  is used as input to another program.”

             — Wikipedia
Syntactic
CUSTOMIZED SYNTAX, EXTEND THE LANGUAGE, ADD
              IMPROVEMENTS
ex. SASS & LESS
Keeping things
 maintainable
SASS
BY HAMPTON CATLIN & NATHAN WEIZENBAUM
Written in Ruby
Don’t worry, there
  are also GUI’s
Watches folders &
compiles on save
2007
ORIGINAL SASS SYNTAX
Hard to convert
existing CSS TO SASS
2010
SASS 3 INTRODUCES SCSS
Regular CSS
      =
 VALID SCSS
BUT WAIT there’s also

 COMPASS
It’s chock full of
   the web’s best
reusable patterns.
Also contains other
   cool features
   IMAGE SPRITING, COLOR FUNCTIONS
LESS
You say
It’s all javascript
ORIGINALLY WRITTEN IN RUBY BY ALEXIS SELLIER
Regular CSS
      =
 VALID LESS
LESS INSPIRED SCSS
LESS
   VS
   SASS
Thanks to Chris Eppstein - https://gist.github.com/674726
Learning curve
YOU HAVE TO KNOW JACK SH*T ABOUT THE CLI
CODEKIT IS HOT!
CSS3 Helpers
SASS HAS COMPASS, LESS DOES NOT
Variables
Mixins
Extending
Custom units in
      SASS
MAKING THE LANGUAGE MORE FUTUREPROOF
Looping
DEMO
Thank you!
Resources:
http://coding.smashingmagazine.com/2011/09/09/an-introduction-to-less-and-
comparison-to-sass/
http://sonspring.com/journal/sass-for-designers
http://css-tricks.com/sass-vs-less/
http://chriseppstein.github.com/blog/2009/09/20/why-stylesheet-abstraction-
matters/
Questions?

Contenu connexe

Similaire à Pre-processing for Fronteers by Viking Kristof Houben

Similaire à Pre-processing for Fronteers by Viking Kristof Houben (20)

The Fast And The Fabulous
The Fast And The FabulousThe Fast And The Fabulous
The Fast And The Fabulous
 
Architecting with Style
Architecting with StyleArchitecting with Style
Architecting with Style
 
LESS is More
LESS is MoreLESS is More
LESS is More
 
Using Sencha Touch to build Cross-platform HTML5 Apps - FITC Screens 2011
Using Sencha Touch to build Cross-platform HTML5 Apps - FITC Screens 2011Using Sencha Touch to build Cross-platform HTML5 Apps - FITC Screens 2011
Using Sencha Touch to build Cross-platform HTML5 Apps - FITC Screens 2011
 
FITC Screens 2011 Presentation - Using Sencha Touch to build Cross-platform H...
FITC Screens 2011 Presentation - Using Sencha Touch to build Cross-platform H...FITC Screens 2011 Presentation - Using Sencha Touch to build Cross-platform H...
FITC Screens 2011 Presentation - Using Sencha Touch to build Cross-platform H...
 
The World of Stylesheet Languages
The World of Stylesheet LanguagesThe World of Stylesheet Languages
The World of Stylesheet Languages
 
Turbo theming: Introduction to Sass & Compass
Turbo theming: Introduction to Sass & CompassTurbo theming: Introduction to Sass & Compass
Turbo theming: Introduction to Sass & Compass
 
CSS-in-JS in React: Why, current state, and bright future.
CSS-in-JS in React: Why, current state, and bright future.CSS-in-JS in React: Why, current state, and bright future.
CSS-in-JS in React: Why, current state, and bright future.
 
Reworking our-workflows
Reworking our-workflowsReworking our-workflows
Reworking our-workflows
 
Front End Badassery with Sass
Front End Badassery with SassFront End Badassery with Sass
Front End Badassery with Sass
 
LESS vs. SASS
LESS vs. SASSLESS vs. SASS
LESS vs. SASS
 
Getting Sassy with CSS
Getting Sassy with CSSGetting Sassy with CSS
Getting Sassy with CSS
 
What is Object Oriented CSS?
What is Object Oriented CSS?What is Object Oriented CSS?
What is Object Oriented CSS?
 
Design and CSS
Design and CSSDesign and CSS
Design and CSS
 
Codestock2018 - CSS vs JS
Codestock2018 - CSS vs JSCodestock2018 - CSS vs JS
Codestock2018 - CSS vs JS
 
Exploring Our Front-End Workflows
Exploring Our Front-End WorkflowsExploring Our Front-End Workflows
Exploring Our Front-End Workflows
 
Scalable front-end architecture with Bootstrap 3 + Atomic CSS
Scalable front-end architecture with Bootstrap 3 + Atomic CSSScalable front-end architecture with Bootstrap 3 + Atomic CSS
Scalable front-end architecture with Bootstrap 3 + Atomic CSS
 
CSS Workflow. Pre & Post
CSS Workflow. Pre & PostCSS Workflow. Pre & Post
CSS Workflow. Pre & Post
 
Postcss brewbox slides
Postcss brewbox slidesPostcss brewbox slides
Postcss brewbox slides
 
NoSQL
NoSQLNoSQL
NoSQL
 

Plus de Mobile Vikings

Plus de Mobile Vikings (20)

Partnership Marketing @ Mobile Vikings
Partnership Marketing @ Mobile VikingsPartnership Marketing @ Mobile Vikings
Partnership Marketing @ Mobile Vikings
 
Our Social Media Approach
Our Social Media ApproachOur Social Media Approach
Our Social Media Approach
 
Social Vikings - Our Customer care via Social Media
Social Vikings - Our Customer care via Social MediaSocial Vikings - Our Customer care via Social Media
Social Vikings - Our Customer care via Social Media
 
Social media Policy
Social media PolicySocial media Policy
Social media Policy
 
Viking ambassadors
Viking ambassadorsViking ambassadors
Viking ambassadors
 
How the Vikings will conquer the world - STIMAC 2013
How the Vikings will conquer the world - STIMAC 2013How the Vikings will conquer the world - STIMAC 2013
How the Vikings will conquer the world - STIMAC 2013
 
Mobile Vikings Business Case for Social Media Club Groningen
Mobile Vikings Business Case for Social Media Club GroningenMobile Vikings Business Case for Social Media Club Groningen
Mobile Vikings Business Case for Social Media Club Groningen
 
Social content strategies (EN)
Social content strategies (EN)Social content strategies (EN)
Social content strategies (EN)
 
Community based marketing bij Mobile Vikings (NL)
Community based marketing bij Mobile Vikings (NL)Community based marketing bij Mobile Vikings (NL)
Community based marketing bij Mobile Vikings (NL)
 
The DNA of Mobile Vikings and community based marketing
The DNA of Mobile Vikings and community based marketingThe DNA of Mobile Vikings and community based marketing
The DNA of Mobile Vikings and community based marketing
 
Student start up
Student start up Student start up
Student start up
 
How Mobile Vikings uses social media
How Mobile Vikings uses social mediaHow Mobile Vikings uses social media
How Mobile Vikings uses social media
 
How Mobile Vikings uses Social Networks
How Mobile Vikings uses Social NetworksHow Mobile Vikings uses Social Networks
How Mobile Vikings uses Social Networks
 
Low budget marketing: The Viking approach
Low budget marketing: The Viking approachLow budget marketing: The Viking approach
Low budget marketing: The Viking approach
 
VikingSpots Next generation
VikingSpots Next generationVikingSpots Next generation
VikingSpots Next generation
 
Marketing de communauté: L’approche de Mobile Vikings
Marketing de communauté: L’approche de Mobile Vikings Marketing de communauté: L’approche de Mobile Vikings
Marketing de communauté: L’approche de Mobile Vikings
 
Mobile vikings DNA Versie 2 (NL)
Mobile vikings DNA Versie 2 (NL)Mobile vikings DNA Versie 2 (NL)
Mobile vikings DNA Versie 2 (NL)
 
Mobile Vikings DNA Version 2 (English)
Mobile Vikings DNA Version 2 (English)Mobile Vikings DNA Version 2 (English)
Mobile Vikings DNA Version 2 (English)
 
Community based marketing: The Viking approach
Community based marketing: The Viking approachCommunity based marketing: The Viking approach
Community based marketing: The Viking approach
 
The Mobile Vikings DNA
The Mobile Vikings DNAThe Mobile Vikings DNA
The Mobile Vikings DNA
 

Dernier

CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
giselly40
 

Dernier (20)

Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Real Time Object Detection Using Open CV
Real Time Object Detection Using Open CVReal Time Object Detection Using Open CV
Real Time Object Detection Using Open CV
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day Presentation
 

Pre-processing for Fronteers by Viking Kristof Houben