SlideShare a Scribd company logo
1 of 32
Download to read offline
DRY CSS
A DON’T-REPEAT-YOURSELF METHODOLOGY
  FOR CREATING EFFICIENT, UNIFIED AND
         SCALABLE STYLESHEETS

    Jeremy Clarke • http://jeremyclarke.org
                 Download these slides:
        http://slideshare.net/jeremyclarke
WHO IS JEREMY CLARKE?


• Communications   Studies at Concordia
 University.

• HTML+CSS     since 2003

• Montreal WordPress
                  Community/
 WordCamp organizer.
OVERVIEW
• An   example of DRY CSS, Global Voices.

• DRY   principle and problems with CSS.

• Preparsers   (LESS and SASS) and their issues.

• DRY   CSS theory, implementation and benefits.

• Appendix: OOCSS
DRY EXAMPLE: GLOBAL VOICES
DRY EXAMPLE: GLOBAL VOICES
                               Before DRY CSS       After DRY CSS


• Applying DRY reduced 4200                                     5,000

 lines to 2400.
                                                               3,750
• Standardized  Shapes, text
 sizes, colors and modules.                                    2,500


                                                            1,250
• Nothinglost, just better
 organized.                                                0
                                     Lines of CSS
DRY EXAMPLE: GLOBAL VOICES

• Groups define shared
 properties.

• Groups   have many selectors.

• Each
     property/value pair is
 defined only once.
DRY EXAMPLE: GLOBAL VOICES
   #ROUNDED5-BORDER2
                  #MEDIUM-ORANGE-TEXT




#PALE-GREY-BACKGROUND
                      #GREY-BUTTON
                    #GREY-BUTTON-HOVER
                    #GREY-BUTTON-CLICK
DRY EXAMPLE: GLOBAL VOICES

• Elegantly organized IE hacks
 and Right-To-Left (RTL)
 styles into groups for the
 common fixes.

• Font-sizegroups re-used in
 optional Large-Font theme.
2 PRINCIPLES OF GOOD CSS

• Keep   style separate from content.

 • HTML  should be structural. Tags, classes and IDs should refer
  to the content itself rather than how it looks.

• Avoid   specificity by harnessing the cascade.

 • Selectors
           and definitions should be as global as possible for
  design consistency and to avoid specificity collisions.
DRY: DON’T REPEAT YOURSELF
• a.k.a   "Single Source of Truth" principle.

• "Everypiece of knowledge must have a single, unambiguous,
 authoritative representation within a system." *

• DRY code means all uses of data change simultaneously rather
 than needing to be replicated.

• DRY  is the fundamental reason to use of variables and
 functions in all programming.

• Bugs      love a wet mess.
                  * http://en.wikipedia.org/wiki/Don't_repeat_yourself
PROBLEMS WITH KEEPING CSS DRY

• No  variables - We can’t re-use values across properties (I.e
 a color hex).

• No  mixins (functions) - No way to re-use sets of property/
 value pairs across definitions.

• Result: Constant   duplication of style definitions across different
 selectors.
BRUTE FORCE: CSS PREPARSERS
•   Add a new language based on CSS that
    has the necessary tools and a new
    parsing layer to read it.

    •   Variables to re-use values across
                                                       Variables in LESS*
        definitions.

    •   Mixins to include a class inside
        another class.

    •   All kinds of other programmy things
        (functions, switch conditions)
                                                       Mixins in LESS*
* E.g. http://lesscss.org/ and http://sass-lang.com/
CSS PREPARSERS: ISSUES

• LESS   and SASS do create a fantastic, DRY-capable CSS.

• BUT  at the cost of destandardization and dependence on
 external libraries. It isn’t CSS.

• They
     can still be misused to create wet, sloppy stylesheets.
 Organizational methodology remains vital.

• Question: How    can we get the same effect with standard CSS?
PRINCIPLES OF DRY CSS
            (TL;DR)
• Don't  Repeat Yourself. Never repeat a style/property
 definition if you can avoid it.

• Group  selectors with shared properties rather than
 defining them separately.
CREATING DRY CSS

• Group selectors that share
 properties above the properties
 they share.

• Name   the groups based on their
 role in the design.

• Use the name as an ID at the top
 of the list and a class at bottom.
ORGANIZING DRY CSS
• Decide on group types and
 groups as necessary for your
 design, operational needs
 and/or other CSS
 methodologies.

• Recommended: Colors, Text,
 Shapes, Structures, Modules.

• At right: GV’s DRY groups,
 visualized by CSSEdit for
 Mac*
                  * http://macrabbit.com/espresso/
KEEPING IT DRY

• Make individual selectors as rare
 and sparse as possible, only use
 them as exceptions.

• Always   have an answer to "Why
 isn't this part of a group?"

• Don’t
      go crazy. Benefits scale even if
 some definitions remain moist.
BENEFITS OF DRY CSS

•2 simple rules to follow that ensure a solid organizational
 structure.

• Less   CSS, shorter and smaller (kb) stylesheets.

• Promotes    good design practice and uniform updates.

• Uses   only philosophically and syntactically standard CSS.
BENEFITS:
     PROMOTES CONCEPTUAL DESIGN
• Encourages  you to think in terms of style patterns (groups),
 rather than individual objects.

• Naming    of groups encourages rational organization of designs.

• Overalldesign tightens up, related objects become stylistically
 paired rather than simply matching.

• Listing
        all group members together encourages optimization
 and generalization of selectors because you see how
 interrelated/inheritable they are.
BENEFITS:
EDITS TO GROUPS AFFECT ALL MEMBERS

• Avoids   need to find all related styles to match changes.

• Changes   are less likely to be inconsistently applied.

• When   testing changes the dev sees all group members change
 as well.

• Moving   selectors between groups to restyle is fast and easy.
BENEFITS:
      TAKES ADVANTAGE OF INSPECTORS
•   Inspecting an object shows cascade of
    groups it participates in.

•   Group "name" (starting ID, i.e.
    #SMALL-TEXT) is visible in inspector.

•   Seeing all group members informs
    dev of related elements that should
    be considered.

•   Live-edits expose the change in
    related items as well.
BENEFITS:
DOESN’T REQUIRE CHANGES TO HTML

• Uses   whatever classes and IDs are already present.

• IfHTML needs editing it's only to add more detailed semantic
  classes to use in your DRY groups.

• Useful
       when generated HTML is out of your control
  (WordPress core/plugins, 3rd party widgets)
BENEFITS:
     COMPLETELY STANDARD
• Simply   an organizing princinple for normal CSS.

• Adheres    to separation of style and content.

• Bothbackward and forward compatible, from IE6 hacks to
 prefixed CSS3 properties.

• CSS    can be pasted anywhere and just work.

• Groupscan be extracted and re-used elsewhere by removing
 group members and inserting new ones.
BENEFITS:
         INTEGRATES WITH OTHER
            METHODOLOGIES
• Compatible with most other CSS methodologies like grids,
 OOCSS* or SMACSS** because the way you organize your
 groups is up to you.

• Progressiveenhancement and browser support is your
 choice. DRY only defines how you organize your selectors and
 properties.

   * https://github.com/stubbornella/oocss/wiki ** http://smacss.com/book/
PERFORMANCE ISSUES?
• TL;DR:      Probably not.

• "Formost web sites, the possible performance gains from
 optimizing CSS selectors will be small, and are not worth the
 costs." ~Steve Sounders*

• Having   many selectors does not inherently hurt performance.

• SeeSteve Sounders research** for optimizations that matter
 (and can be applied to DRY CSS).
  * http://www.stevesouders.com/blog/2009/03/10/performance-impact-of-css-selectors/
        ** http://www.stevesouders.com/blog/2009/06/18/simplifying-css-selectors/
OOCSS: "OBJECT ORIENTED"
• “Separate   structure and           • Implementation
 skin.”
                                         • Define   re-usable classes
• “Separate   container and                like .media, .box and .red
 content.”
                                         • Add  them to HTML tags
• Objectsare re-usable                     throughout your site to
 content patterns.                         create a consistent and
                                           efficient design.
• Skins
      are sets of visual
 decorations to be applied to
 objects.                                                              Sources
                               https://github.com/stubbornella/oocss/wiki/FAQ
                         http://slideshare.net/stubbornella/object-oriented-css
DRY CSS <3 OOCSS
• The   fundamental principles and goals are the same:

 • Create   logical style groups that define your site.

 • Apply  them to elements rather than redefining css on many
   selectors.

 • Focus  on consistency of objects across the site through
   direct style linkage.

• “Object-orientation” can
                        be integrated into a DRY approach
 when choosing your groups and group types.
DRY CSS > OOCSS
• The    difference:

  • DRY     stacks selectors above a single definition in the CSS.

  • OOCSS  applies generic classes to HTML tags throughout
   the document.

• OOCSS    violates the separation of content and style by
 polluting HTML with meaningless style-classes.

     is unnecessary because DRY CSS can achieve the
• This
 same goal while maintaining separation.
DRY CSS > OOCSS (DETAILS)
• DRY offers an easy way to route around situations where
 OOCSS classes can't be added to HTML (out of your
 control, inconvenient, undesirable).

• Generic  group class (i.e .small-text) for each DRY group can
 still be used in OOCSS way if needed (especially in transient
 content rather than templates).

• DRY  allows group membership to be managed without
 editing HTML templates. Less files to edit, less people involved.

• DRY   keeps style and content separate LIKE IT SHOULD BE.
DRY CSS REVIEW
Group re-usable     Name the         Add selectors to
  properties      groups logically    various groups
QUESTIONS?
DRY CSS
A DON’T-REPEAT-YOURSELF METHODOLOGY
  FOR CREATING EFFICIENT, UNIFIED AND
         SCALABLE STYLESHEETS

Jeremy Clarke • http://jeremyclarke.org

                  Creative Commons Share Alike
                   http://creativecommons.org/licenses/by-sa/3.0/



                 Download these slides:
        http://slideshare.net/jeremyclarke

More Related Content

What's hot

Deep dive into sass
Deep dive into sassDeep dive into sass
Deep dive into sassKnoldus Inc.
 
Styled Components & React.js
Styled Components & React.jsStyled Components & React.js
Styled Components & React.jsGrayson Hicks
 
Intro to css & sass
Intro to css & sassIntro to css & sass
Intro to css & sassSean Wolfe
 
About Best friends - HTML, CSS and JS
About Best friends - HTML, CSS and JSAbout Best friends - HTML, CSS and JS
About Best friends - HTML, CSS and JSNaga Harish M
 
An Introduction to CSS Preprocessors (SASS & LESS)
An Introduction to CSS Preprocessors (SASS & LESS)An Introduction to CSS Preprocessors (SASS & LESS)
An Introduction to CSS Preprocessors (SASS & LESS)Folio3 Software
 
CSS Animations & Transitions
CSS Animations & TransitionsCSS Animations & Transitions
CSS Animations & TransitionsEdward Meehan
 
Introduction to SASS
Introduction to SASSIntroduction to SASS
Introduction to SASSJon Dean
 
How to manage a big scale HTML/CSS project
How to manage a big scale HTML/CSS projectHow to manage a big scale HTML/CSS project
How to manage a big scale HTML/CSS projectRenoir Boulanger
 
Introducing CSS Grid Layout
Introducing CSS Grid LayoutIntroducing CSS Grid Layout
Introducing CSS Grid LayoutRachel Andrew
 
Introduction to HTML and CSS
Introduction to HTML and CSSIntroduction to HTML and CSS
Introduction to HTML and CSSMario Hernandez
 
Sling Models Using Sightly and JSP by Deepak Khetawat
Sling Models Using Sightly and JSP by Deepak KhetawatSling Models Using Sightly and JSP by Deepak Khetawat
Sling Models Using Sightly and JSP by Deepak KhetawatAEM HUB
 
Introduction to CSS3
Introduction to CSS3Introduction to CSS3
Introduction to CSS3Doris Chen
 
Cascading Style Sheets (CSS) help
Cascading Style Sheets (CSS) helpCascading Style Sheets (CSS) help
Cascading Style Sheets (CSS) helpcasestudyhelp
 

What's hot (20)

Sass presentation
Sass presentationSass presentation
Sass presentation
 
Deep dive into sass
Deep dive into sassDeep dive into sass
Deep dive into sass
 
Styled Components & React.js
Styled Components & React.jsStyled Components & React.js
Styled Components & React.js
 
Intro to css & sass
Intro to css & sassIntro to css & sass
Intro to css & sass
 
About Best friends - HTML, CSS and JS
About Best friends - HTML, CSS and JSAbout Best friends - HTML, CSS and JS
About Best friends - HTML, CSS and JS
 
An Introduction to CSS Preprocessors (SASS & LESS)
An Introduction to CSS Preprocessors (SASS & LESS)An Introduction to CSS Preprocessors (SASS & LESS)
An Introduction to CSS Preprocessors (SASS & LESS)
 
Introduction to sass
Introduction to sassIntroduction to sass
Introduction to sass
 
css.ppt
css.pptcss.ppt
css.ppt
 
CSS Animations & Transitions
CSS Animations & TransitionsCSS Animations & Transitions
CSS Animations & Transitions
 
Less vs sass
Less vs sassLess vs sass
Less vs sass
 
Introducing CSS Grid
Introducing CSS GridIntroducing CSS Grid
Introducing CSS Grid
 
Introduction to SASS
Introduction to SASSIntroduction to SASS
Introduction to SASS
 
Bootstrap 5 basic
Bootstrap 5 basicBootstrap 5 basic
Bootstrap 5 basic
 
How to manage a big scale HTML/CSS project
How to manage a big scale HTML/CSS projectHow to manage a big scale HTML/CSS project
How to manage a big scale HTML/CSS project
 
Introducing CSS Grid Layout
Introducing CSS Grid LayoutIntroducing CSS Grid Layout
Introducing CSS Grid Layout
 
Introduction to HTML and CSS
Introduction to HTML and CSSIntroduction to HTML and CSS
Introduction to HTML and CSS
 
BEM - CSS, Seriously
BEM - CSS, SeriouslyBEM - CSS, Seriously
BEM - CSS, Seriously
 
Sling Models Using Sightly and JSP by Deepak Khetawat
Sling Models Using Sightly and JSP by Deepak KhetawatSling Models Using Sightly and JSP by Deepak Khetawat
Sling Models Using Sightly and JSP by Deepak Khetawat
 
Introduction to CSS3
Introduction to CSS3Introduction to CSS3
Introduction to CSS3
 
Cascading Style Sheets (CSS) help
Cascading Style Sheets (CSS) helpCascading Style Sheets (CSS) help
Cascading Style Sheets (CSS) help
 

Viewers also liked

Put A Map On It! Enhanced geolocation in WordPress with Geo Mashup
Put A Map On It! Enhanced geolocation in WordPress with Geo MashupPut A Map On It! Enhanced geolocation in WordPress with Geo Mashup
Put A Map On It! Enhanced geolocation in WordPress with Geo MashupJer Clarke
 
Методологии верстки
Методологии версткиМетодологии верстки
Методологии версткиElizaveta Selivanova
 
Our Best Practices Are Killing Us
Our Best Practices Are Killing UsOur Best Practices Are Killing Us
Our Best Practices Are Killing UsNicole Sullivan
 
Keep Your Code Organized! WordCamp Montreal 2013 Presentation slides
Keep Your Code Organized! WordCamp Montreal 2013 Presentation slidesKeep Your Code Organized! WordCamp Montreal 2013 Presentation slides
Keep Your Code Organized! WordCamp Montreal 2013 Presentation slidesJer Clarke
 
CSS Methodology
CSS MethodologyCSS Methodology
CSS MethodologyZohar Arad
 
BEM It! for Brandwatch
BEM It! for BrandwatchBEM It! for Brandwatch
BEM It! for BrandwatchMax Shirshin
 
Architecting single-page front-end apps
Architecting single-page front-end appsArchitecting single-page front-end apps
Architecting single-page front-end appsZohar Arad
 
Css3 and gwt in perfect harmony
Css3 and gwt in perfect harmonyCss3 and gwt in perfect harmony
Css3 and gwt in perfect harmonyArcbees
 
What is Elm and Why Should I care?
What is Elm and Why Should I care?What is Elm and Why Should I care?
What is Elm and Why Should I care?Thomas Groshong
 
Responsive Design Workflow (Breaking Development Conference 2012 Orlando)
Responsive Design Workflow (Breaking Development Conference 2012 Orlando)Responsive Design Workflow (Breaking Development Conference 2012 Orlando)
Responsive Design Workflow (Breaking Development Conference 2012 Orlando)Stephen Hay
 
The Why and What of Pattern Lab
The Why and What of Pattern LabThe Why and What of Pattern Lab
The Why and What of Pattern LabDave Olsen
 
Incorporating Video into your Link Building Strategy
Incorporating Video into your Link Building StrategyIncorporating Video into your Link Building Strategy
Incorporating Video into your Link Building StrategyPhil Nottingham
 

Viewers also liked (20)

Put A Map On It! Enhanced geolocation in WordPress with Geo Mashup
Put A Map On It! Enhanced geolocation in WordPress with Geo MashupPut A Map On It! Enhanced geolocation in WordPress with Geo Mashup
Put A Map On It! Enhanced geolocation in WordPress with Geo Mashup
 
Object Oriented CSS
Object Oriented CSSObject Oriented CSS
Object Oriented CSS
 
Atomic design
Atomic designAtomic design
Atomic design
 
Методологии верстки
Методологии версткиМетодологии верстки
Методологии верстки
 
Our Best Practices Are Killing Us
Our Best Practices Are Killing UsOur Best Practices Are Killing Us
Our Best Practices Are Killing Us
 
Css Preprocessors
Css PreprocessorsCss Preprocessors
Css Preprocessors
 
Keep Your Code Organized! WordCamp Montreal 2013 Presentation slides
Keep Your Code Organized! WordCamp Montreal 2013 Presentation slidesKeep Your Code Organized! WordCamp Montreal 2013 Presentation slides
Keep Your Code Organized! WordCamp Montreal 2013 Presentation slides
 
DRY CSS
DRY CSSDRY CSS
DRY CSS
 
Contropedia - Mockup
Contropedia - MockupContropedia - Mockup
Contropedia - Mockup
 
CSS Methodology
CSS MethodologyCSS Methodology
CSS Methodology
 
BEM It! for Brandwatch
BEM It! for BrandwatchBEM It! for Brandwatch
BEM It! for Brandwatch
 
Architecting single-page front-end apps
Architecting single-page front-end appsArchitecting single-page front-end apps
Architecting single-page front-end apps
 
Css3 and gwt in perfect harmony
Css3 and gwt in perfect harmonyCss3 and gwt in perfect harmony
Css3 and gwt in perfect harmony
 
Killer form design
Killer form designKiller form design
Killer form design
 
Scalable CSS Architecture
Scalable CSS ArchitectureScalable CSS Architecture
Scalable CSS Architecture
 
What is Elm and Why Should I care?
What is Elm and Why Should I care?What is Elm and Why Should I care?
What is Elm and Why Should I care?
 
Responsive Design Workflow (Breaking Development Conference 2012 Orlando)
Responsive Design Workflow (Breaking Development Conference 2012 Orlando)Responsive Design Workflow (Breaking Development Conference 2012 Orlando)
Responsive Design Workflow (Breaking Development Conference 2012 Orlando)
 
CSS Bloat!
CSS Bloat!CSS Bloat!
CSS Bloat!
 
The Why and What of Pattern Lab
The Why and What of Pattern LabThe Why and What of Pattern Lab
The Why and What of Pattern Lab
 
Incorporating Video into your Link Building Strategy
Incorporating Video into your Link Building StrategyIncorporating Video into your Link Building Strategy
Incorporating Video into your Link Building Strategy
 

Similar to DRY CSS A don’t-repeat-yourself methodology for creating efficient, unified and Scalable stylesheets

WordCamp NYC - DRY CSS
WordCamp NYC - DRY CSSWordCamp NYC - DRY CSS
WordCamp NYC - DRY CSSJer Clarke
 
What is-sass-by-lucas-castro
What is-sass-by-lucas-castroWhat is-sass-by-lucas-castro
What is-sass-by-lucas-castroLucas Castro
 
Complete Lecture on Css presentation
Complete Lecture on Css presentation Complete Lecture on Css presentation
Complete Lecture on Css presentation Salman Memon
 
4. Web Technology CSS Basics-1
4. Web Technology CSS Basics-14. Web Technology CSS Basics-1
4. Web Technology CSS Basics-1Jyoti Yadav
 
Minimalist Theming: How to Build a Lean, Mean Drupal 8 Theme
Minimalist Theming: How to Build a Lean, Mean Drupal 8 ThemeMinimalist Theming: How to Build a Lean, Mean Drupal 8 Theme
Minimalist Theming: How to Build a Lean, Mean Drupal 8 ThemeSuzanne Dergacheva
 
WEBD 162: Intro to CSS
WEBD 162: Intro to CSSWEBD 162: Intro to CSS
WEBD 162: Intro to CSSpalomateach
 
Web design-workflow
Web design-workflowWeb design-workflow
Web design-workflowPeter Kaizer
 
Sane CSS - A modern approach to CSS
Sane CSS - A modern approach to CSSSane CSS - A modern approach to CSS
Sane CSS - A modern approach to CSSLee Cheneler
 
Object Oriented CSS for rapid, scalable and maintainable development
Object Oriented CSS for rapid, scalable and maintainable developmentObject Oriented CSS for rapid, scalable and maintainable development
Object Oriented CSS for rapid, scalable and maintainable developmentGraeme Blackwood
 
Css presentation lecture 3
Css presentation lecture 3Css presentation lecture 3
Css presentation lecture 3Mudasir Syed
 
Css presentation lecture 1
Css presentation lecture 1Css presentation lecture 1
Css presentation lecture 1Mudasir Syed
 
Css week10 2019 2020 for g10 by eng.osama ghandour
Css week10 2019 2020 for g10 by eng.osama ghandourCss week10 2019 2020 for g10 by eng.osama ghandour
Css week10 2019 2020 for g10 by eng.osama ghandourOsama Ghandour Geris
 
CSS for Design Systems
CSS for Design SystemsCSS for Design Systems
CSS for Design SystemsAdam Kudrna
 

Similar to DRY CSS A don’t-repeat-yourself methodology for creating efficient, unified and Scalable stylesheets (20)

WordCamp NYC - DRY CSS
WordCamp NYC - DRY CSSWordCamp NYC - DRY CSS
WordCamp NYC - DRY CSS
 
What is-sass-by-lucas-castro
What is-sass-by-lucas-castroWhat is-sass-by-lucas-castro
What is-sass-by-lucas-castro
 
Complete Lecture on Css presentation
Complete Lecture on Css presentation Complete Lecture on Css presentation
Complete Lecture on Css presentation
 
4. Web Technology CSS Basics-1
4. Web Technology CSS Basics-14. Web Technology CSS Basics-1
4. Web Technology CSS Basics-1
 
Minimalist Theming: How to Build a Lean, Mean Drupal 8 Theme
Minimalist Theming: How to Build a Lean, Mean Drupal 8 ThemeMinimalist Theming: How to Build a Lean, Mean Drupal 8 Theme
Minimalist Theming: How to Build a Lean, Mean Drupal 8 Theme
 
WEBD 162: Intro to CSS
WEBD 162: Intro to CSSWEBD 162: Intro to CSS
WEBD 162: Intro to CSS
 
Css tutorial 2012
Css tutorial 2012Css tutorial 2012
Css tutorial 2012
 
DW unit 3.pptx
DW unit 3.pptxDW unit 3.pptx
DW unit 3.pptx
 
DHTML
DHTMLDHTML
DHTML
 
Web design-workflow
Web design-workflowWeb design-workflow
Web design-workflow
 
Sane CSS - A modern approach to CSS
Sane CSS - A modern approach to CSSSane CSS - A modern approach to CSS
Sane CSS - A modern approach to CSS
 
Object Oriented CSS for rapid, scalable and maintainable development
Object Oriented CSS for rapid, scalable and maintainable developmentObject Oriented CSS for rapid, scalable and maintainable development
Object Oriented CSS for rapid, scalable and maintainable development
 
Css Systems
Css SystemsCss Systems
Css Systems
 
Css presentation lecture 3
Css presentation lecture 3Css presentation lecture 3
Css presentation lecture 3
 
Css presentation lecture 1
Css presentation lecture 1Css presentation lecture 1
Css presentation lecture 1
 
Css week10 2019 2020 for g10 by eng.osama ghandour
Css week10 2019 2020 for g10 by eng.osama ghandourCss week10 2019 2020 for g10 by eng.osama ghandour
Css week10 2019 2020 for g10 by eng.osama ghandour
 
CSS for Design Systems
CSS for Design SystemsCSS for Design Systems
CSS for Design Systems
 
What is Modular CSS?
What is Modular CSS?What is Modular CSS?
What is Modular CSS?
 
Intro to css
Intro to cssIntro to css
Intro to css
 
Dangerous CSS
Dangerous CSSDangerous CSS
Dangerous CSS
 

More from Jer Clarke

globalvoices.org - How our CC license spawned a world class translation commu...
globalvoices.org - How our CC license spawned a world class translation commu...globalvoices.org - How our CC license spawned a world class translation commu...
globalvoices.org - How our CC license spawned a world class translation commu...Jer Clarke
 
Global Voices proves Creative Commons is Awesome • CC Salon Montreal
Global Voices proves Creative Commons is Awesome • CC Salon MontrealGlobal Voices proves Creative Commons is Awesome • CC Salon Montreal
Global Voices proves Creative Commons is Awesome • CC Salon MontrealJer Clarke
 
Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...
Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...
Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...Jer Clarke
 
NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009
NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009
NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009Jer Clarke
 
Caching and Optimization for WordPress
Caching and Optimization for WordPressCaching and Optimization for WordPress
Caching and Optimization for WordPressJer Clarke
 
WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09
WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09
WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09Jer Clarke
 
Global Voices Generic Presentation
Global Voices Generic PresentationGlobal Voices Generic Presentation
Global Voices Generic PresentationJer Clarke
 
Global Voices - Democratising the web with Wordpress and Love
Global Voices - Democratising the web with Wordpress and LoveGlobal Voices - Democratising the web with Wordpress and Love
Global Voices - Democratising the web with Wordpress and LoveJer Clarke
 

More from Jer Clarke (8)

globalvoices.org - How our CC license spawned a world class translation commu...
globalvoices.org - How our CC license spawned a world class translation commu...globalvoices.org - How our CC license spawned a world class translation commu...
globalvoices.org - How our CC license spawned a world class translation commu...
 
Global Voices proves Creative Commons is Awesome • CC Salon Montreal
Global Voices proves Creative Commons is Awesome • CC Salon MontrealGlobal Voices proves Creative Commons is Awesome • CC Salon Montreal
Global Voices proves Creative Commons is Awesome • CC Salon Montreal
 
Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...
Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...
Widgetize Everything: Building smarter WordPress themes with Widgets and Temp...
 
NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009
NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009
NetBeans, IDEs and faster programming for WordPress - WordCamp NYC 2009
 
Caching and Optimization for WordPress
Caching and Optimization for WordPressCaching and Optimization for WordPress
Caching and Optimization for WordPress
 
WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09
WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09
WordPress Code and Setup Strategies and Advice, WordCamp Toronto '09
 
Global Voices Generic Presentation
Global Voices Generic PresentationGlobal Voices Generic Presentation
Global Voices Generic Presentation
 
Global Voices - Democratising the web with Wordpress and Love
Global Voices - Democratising the web with Wordpress and LoveGlobal Voices - Democratising the web with Wordpress and Love
Global Voices - Democratising the web with Wordpress and Love
 

Recently uploaded

Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024The Digital Insurer
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUK Journal
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)wesley chun
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
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 productivityPrincipled Technologies
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024The Digital Insurer
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProduct Anonymous
 
Tech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfTech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfhans926745
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)Gabriella Davis
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processorsdebabhi2
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoffsammart93
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...Martijn de Jong
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...apidays
 
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 AutomationSafe Software
 
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 WorkerThousandEyes
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherRemote DBA Services
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobeapidays
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024The Digital Insurer
 

Recently uploaded (20)

Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
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
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Tech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfTech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdf
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processors
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
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
 
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
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024
 

DRY CSS A don’t-repeat-yourself methodology for creating efficient, unified and Scalable stylesheets

  • 1. DRY CSS A DON’T-REPEAT-YOURSELF METHODOLOGY FOR CREATING EFFICIENT, UNIFIED AND SCALABLE STYLESHEETS Jeremy Clarke • http://jeremyclarke.org Download these slides: http://slideshare.net/jeremyclarke
  • 2. WHO IS JEREMY CLARKE? • Communications Studies at Concordia University. • HTML+CSS since 2003 • Montreal WordPress Community/ WordCamp organizer.
  • 3. OVERVIEW • An example of DRY CSS, Global Voices. • DRY principle and problems with CSS. • Preparsers (LESS and SASS) and their issues. • DRY CSS theory, implementation and benefits. • Appendix: OOCSS
  • 5. DRY EXAMPLE: GLOBAL VOICES Before DRY CSS After DRY CSS • Applying DRY reduced 4200 5,000 lines to 2400. 3,750 • Standardized Shapes, text sizes, colors and modules. 2,500 1,250 • Nothinglost, just better organized. 0 Lines of CSS
  • 6. DRY EXAMPLE: GLOBAL VOICES • Groups define shared properties. • Groups have many selectors. • Each property/value pair is defined only once.
  • 7. DRY EXAMPLE: GLOBAL VOICES #ROUNDED5-BORDER2 #MEDIUM-ORANGE-TEXT #PALE-GREY-BACKGROUND #GREY-BUTTON #GREY-BUTTON-HOVER #GREY-BUTTON-CLICK
  • 8. DRY EXAMPLE: GLOBAL VOICES • Elegantly organized IE hacks and Right-To-Left (RTL) styles into groups for the common fixes. • Font-sizegroups re-used in optional Large-Font theme.
  • 9. 2 PRINCIPLES OF GOOD CSS • Keep style separate from content. • HTML should be structural. Tags, classes and IDs should refer to the content itself rather than how it looks. • Avoid specificity by harnessing the cascade. • Selectors and definitions should be as global as possible for design consistency and to avoid specificity collisions.
  • 10. DRY: DON’T REPEAT YOURSELF • a.k.a "Single Source of Truth" principle. • "Everypiece of knowledge must have a single, unambiguous, authoritative representation within a system." * • DRY code means all uses of data change simultaneously rather than needing to be replicated. • DRY is the fundamental reason to use of variables and functions in all programming. • Bugs love a wet mess. * http://en.wikipedia.org/wiki/Don't_repeat_yourself
  • 11. PROBLEMS WITH KEEPING CSS DRY • No variables - We can’t re-use values across properties (I.e a color hex). • No mixins (functions) - No way to re-use sets of property/ value pairs across definitions. • Result: Constant duplication of style definitions across different selectors.
  • 12. BRUTE FORCE: CSS PREPARSERS • Add a new language based on CSS that has the necessary tools and a new parsing layer to read it. • Variables to re-use values across Variables in LESS* definitions. • Mixins to include a class inside another class. • All kinds of other programmy things (functions, switch conditions) Mixins in LESS* * E.g. http://lesscss.org/ and http://sass-lang.com/
  • 13. CSS PREPARSERS: ISSUES • LESS and SASS do create a fantastic, DRY-capable CSS. • BUT at the cost of destandardization and dependence on external libraries. It isn’t CSS. • They can still be misused to create wet, sloppy stylesheets. Organizational methodology remains vital. • Question: How can we get the same effect with standard CSS?
  • 14. PRINCIPLES OF DRY CSS (TL;DR) • Don't Repeat Yourself. Never repeat a style/property definition if you can avoid it. • Group selectors with shared properties rather than defining them separately.
  • 15. CREATING DRY CSS • Group selectors that share properties above the properties they share. • Name the groups based on their role in the design. • Use the name as an ID at the top of the list and a class at bottom.
  • 16. ORGANIZING DRY CSS • Decide on group types and groups as necessary for your design, operational needs and/or other CSS methodologies. • Recommended: Colors, Text, Shapes, Structures, Modules. • At right: GV’s DRY groups, visualized by CSSEdit for Mac* * http://macrabbit.com/espresso/
  • 17. KEEPING IT DRY • Make individual selectors as rare and sparse as possible, only use them as exceptions. • Always have an answer to "Why isn't this part of a group?" • Don’t go crazy. Benefits scale even if some definitions remain moist.
  • 18. BENEFITS OF DRY CSS •2 simple rules to follow that ensure a solid organizational structure. • Less CSS, shorter and smaller (kb) stylesheets. • Promotes good design practice and uniform updates. • Uses only philosophically and syntactically standard CSS.
  • 19. BENEFITS: PROMOTES CONCEPTUAL DESIGN • Encourages you to think in terms of style patterns (groups), rather than individual objects. • Naming of groups encourages rational organization of designs. • Overalldesign tightens up, related objects become stylistically paired rather than simply matching. • Listing all group members together encourages optimization and generalization of selectors because you see how interrelated/inheritable they are.
  • 20. BENEFITS: EDITS TO GROUPS AFFECT ALL MEMBERS • Avoids need to find all related styles to match changes. • Changes are less likely to be inconsistently applied. • When testing changes the dev sees all group members change as well. • Moving selectors between groups to restyle is fast and easy.
  • 21. BENEFITS: TAKES ADVANTAGE OF INSPECTORS • Inspecting an object shows cascade of groups it participates in. • Group "name" (starting ID, i.e. #SMALL-TEXT) is visible in inspector. • Seeing all group members informs dev of related elements that should be considered. • Live-edits expose the change in related items as well.
  • 22. BENEFITS: DOESN’T REQUIRE CHANGES TO HTML • Uses whatever classes and IDs are already present. • IfHTML needs editing it's only to add more detailed semantic classes to use in your DRY groups. • Useful when generated HTML is out of your control (WordPress core/plugins, 3rd party widgets)
  • 23. BENEFITS: COMPLETELY STANDARD • Simply an organizing princinple for normal CSS. • Adheres to separation of style and content. • Bothbackward and forward compatible, from IE6 hacks to prefixed CSS3 properties. • CSS can be pasted anywhere and just work. • Groupscan be extracted and re-used elsewhere by removing group members and inserting new ones.
  • 24. BENEFITS: INTEGRATES WITH OTHER METHODOLOGIES • Compatible with most other CSS methodologies like grids, OOCSS* or SMACSS** because the way you organize your groups is up to you. • Progressiveenhancement and browser support is your choice. DRY only defines how you organize your selectors and properties. * https://github.com/stubbornella/oocss/wiki ** http://smacss.com/book/
  • 25. PERFORMANCE ISSUES? • TL;DR: Probably not. • "Formost web sites, the possible performance gains from optimizing CSS selectors will be small, and are not worth the costs." ~Steve Sounders* • Having many selectors does not inherently hurt performance. • SeeSteve Sounders research** for optimizations that matter (and can be applied to DRY CSS). * http://www.stevesouders.com/blog/2009/03/10/performance-impact-of-css-selectors/ ** http://www.stevesouders.com/blog/2009/06/18/simplifying-css-selectors/
  • 26. OOCSS: "OBJECT ORIENTED" • “Separate structure and • Implementation skin.” • Define re-usable classes • “Separate container and like .media, .box and .red content.” • Add them to HTML tags • Objectsare re-usable throughout your site to content patterns. create a consistent and efficient design. • Skins are sets of visual decorations to be applied to objects. Sources https://github.com/stubbornella/oocss/wiki/FAQ http://slideshare.net/stubbornella/object-oriented-css
  • 27. DRY CSS <3 OOCSS • The fundamental principles and goals are the same: • Create logical style groups that define your site. • Apply them to elements rather than redefining css on many selectors. • Focus on consistency of objects across the site through direct style linkage. • “Object-orientation” can be integrated into a DRY approach when choosing your groups and group types.
  • 28. DRY CSS > OOCSS • The difference: • DRY stacks selectors above a single definition in the CSS. • OOCSS applies generic classes to HTML tags throughout the document. • OOCSS violates the separation of content and style by polluting HTML with meaningless style-classes. is unnecessary because DRY CSS can achieve the • This same goal while maintaining separation.
  • 29. DRY CSS > OOCSS (DETAILS) • DRY offers an easy way to route around situations where OOCSS classes can't be added to HTML (out of your control, inconvenient, undesirable). • Generic group class (i.e .small-text) for each DRY group can still be used in OOCSS way if needed (especially in transient content rather than templates). • DRY allows group membership to be managed without editing HTML templates. Less files to edit, less people involved. • DRY keeps style and content separate LIKE IT SHOULD BE.
  • 30. DRY CSS REVIEW Group re-usable Name the Add selectors to properties groups logically various groups
  • 32. DRY CSS A DON’T-REPEAT-YOURSELF METHODOLOGY FOR CREATING EFFICIENT, UNIFIED AND SCALABLE STYLESHEETS Jeremy Clarke • http://jeremyclarke.org Creative Commons Share Alike http://creativecommons.org/licenses/by-sa/3.0/ Download these slides: http://slideshare.net/jeremyclarke