Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Intégrateurs, bousculez vos habitudes !

Raphael Goetter
October 11, 2013

Intégrateurs, bousculez vos habitudes !

Paris-Web 2013

Depuis que je fais de l'intégration (un paquet d'années), j'ai toujours été très concerné par les standards, l'accessibilité et la sémantique.
Il se trouve cependant qu'avec l'expérience, on se rend compte que les contraintes de production et de performances ont bien évolué en 15 ans : à force de respecter d'antiques préceptes on crée des fichiers CSS lourds, redondant, et non réutilisables. C'est pourquoi 12% des plus gros sites mondiaux comptent plus de 50 occurences de "!important".

Ces aberrations peuvent être évitées en utilisant judicieusement des CSS efficaces. Nicole Sullivan (ex-Yahoo!) a ouvert la voie en créant "OOCSS" (CSS orientés “objet”), d’autres tels que Jonathan Snooks ou Kaelig Deloumeau-Prigent ont suivi le mouvement.

Raphael Goetter

October 11, 2013
Tweet

More Decks by Raphael Goetter

Other Decks in Design

Transcript

  1. Les navigateurs ont évolué HTML et CSS ont mûri Les

    besoins, les projets, les utilisateurs ont changé Notre métier n'est plus le même Il est indispensable de nous adapter ! #CONTEXTE
  2. « S » Agence web Située en Alsace 8 personnes

    Compétences diverses Pas de commercial Projets variés
  3. MAIS ÇA C'ÉTAIT AVANT ! balises propriétaires spacer.gif <table> IE

    5 / Netscape 4 applets Java frontpage framesets WYSIWYG <font> position : absolute <center> style= colspan
  4. tableaux de mise en page FrontPage, Dreamweaver divite, classite Flash

    JavaScript IE6 (IE tout court ?) sélecteur joker * préfixes constructeurs C'EST MAL !
  5. HTML épuré CSS épuré modèle de boîte standard id pour

    les éléments uniques classes pour des éléments multiples fermer les balises HTML être valide W3C jQuery (et ses copains) C'EST BIEN !
  6. Des délais à respecter il faut aller vite, être productif,

    s’adapter Des intervenants multiples des experts, des novices, des développeurs, graphistes Au secours, un nouveau ! l’équipe évolue, des nouveaux arrivent pendant le projet Un projet et ses specs évoluent toujours produire un code cohérent, souple et réutilisable
  7. ALEXA.COM Top 1000 rank 12% plus de 50 fois →

    !important 13% plus de 100 fois → float 25% plus de 100 fois → font-size Facebook … 261 valeurs de la couleur bleue Photo : fotolia Les styles CSS des gros sites mondiaux :
  8. ALEXA.COM Top 1000 rank 12% plus de 50 fois →

    !important 13% plus de 100 fois → float 25% plus de 100 fois → font-size Facebook … 261 valeurs de la couleur bleue Photo : fotolia Les styles CSS des gros sites mondiaux : lourd pas maintenable MAL pas performant pas compréhensible
  9. C'EST MAL ! C'EST BIEN ! EUH ? tableaux de

    mise en page FrontPage, Dreamweaver divite, classite Flash JavaScript IE6 (IE tout court ?) sélecteur joker * préfixes constructeurs les frameworks les préprocesseurs HTML épuré CSS épuré modèle de boîte standard id = éléments uniques classes = éléments multiples être valide W3C jQuery (et ses copains) ou pas ! ou pas ! ou pas !
  10. C'EST MAL ! C'EST BIEN ! EUH ? tableaux de

    mise en page FrontPage, Dreamweaver divite, classite Flash JavaScript IE6 (IE tout court ?) sélecteur joker * préfixes constructeurs les frameworks les préprocesseurs HTML épuré CSS épuré modèle de boîte standard id = éléments uniques classes = éléments multiples être valide W3C jQuery (et ses copains) ou pas ! ou pas ! ou pas !
  11. Bousculons nos dogmes ! #osons! ou pas ! ou pas

    ! ou pas ! C'EST MAL ! C'EST BIEN ! EUH ?
  12. Box-sizing c'est super dangereux et ça pique – moi “

    Les préprocesseurs CSS, ça sert à rien – encore moi “ Chrome est un super navigateur ! – toujours moi (oui bon hein ça va) “ TOUT LE MONDE PEUT SE TROMPER ! Apprenons de nos erreurs, testons, avançons
  13. Nos techniques Nos outils Nos méthodes BOUSCULONS NOS HABITUDES !

    ❶ ❷ ❸ #positionnements #box-sizing #sélecteurs #préfixes #frameworks #préprocesseurs #conventions #InternetExplorer #IDvsCLASS! #OOCSS
  14. ❶ POSITIONNEMENT CSS frames, <table> position : absolute float display

    : inline-block display : table-cell columns flexbox grid layout, regions, ... #FearZone #HoaxZone #NoobZone La « zone de confiance »
  15. ❶ POSITIONNEMENT CSS Display : inline-block <p> <blockquote> p {

    display: inline-block; width: 10em; } blockquote ~ p { vertical-align: top; }
  16. ❶ POSITIONNEMENT CSS ul { display: table; } li {

    display: table-cell; width: 20%; } li:hover { width: 40%; } kiwi.gg/tablenav (+ bonus : apple.com) Display : table
  17. ❶ SÉLECTION D'ÉLÉMENTS jQuery of course ! Made by Chuck

    Norris <script> $("input[name*='man']").css("background","red"); </script>
  18. ❶ SÉLECTION D'ÉLÉMENTS jQuery of course ! Made by Chuck

    Norris #really ? <script> $("input[name*='man']").css("background","red"); </script>
  19. ❶ SÉLECTION D'ÉLÉMENTS :first-child premier enfant → élt + élt

    frère suivant direct → élt ~ élt tous les frères suivants → [attr^="valeur"] attribut qui commence par «valeur» → [attr$="valeur"] attribut qui termine par «valeur» → [attr*="valeur"] attribut qui contient «valeur» → élt:hover élément survolé → Sélecteurs CSS « avancés »
  20. :first-child élt + élt élt ~ élt [attr^="valeur"] [attr$="valeur"] [attr*="valeur"]

    élt:hover ❶ SÉLECTION D'ÉLÉMENTS Sélecteurs CSS « avancés » qui marchent partout !
  21. ❶ SÉLECTION D'ÉLÉMENTS jQuery of course (ou pas) ! [name*=man]

    { background: red; } = <script> $("input[name*='man']").css("background","red"); </script>
  22. ❶ li:first-child + li + li { background-color: yellow; }

    SÉLECTION D'ÉLÉMENTS Cibler le 3e <li> ? Facile ! :first-child élt + élt élt ~ élt [attr^="valeur"] [attr$="valeur"] [attr*="valeur"] élt:hover
  23. ❶ [class^="icon-"] { ici des trucs cools } .icon-info, .icon-mail,

    .icon-skyblog, .icon-post, .icon-delete, ... SÉLECTION D'ÉLÉMENTS Cibler un groupe de classes ? Facile !
  24. ❶ PRÉFIXES CONSTRUCTEURS div { -webkit-border-radius : 50%; -moz-border-radius :

    50%; -ms-border-radius : 50%; -o-border-radius : 50%; border-radius : 50%; }
  25. ❶ PRÉFIXES CONSTRUCTEURS div { -webkit-border-radius : 50%; -moz-border-radius :

    50%; -ms-border-radius : 50%; -o-border-radius : 50%; border-radius : 50%; } #noob #noob
  26. ❶ PRÉFIXES CONSTRUCTEURS div { -webkit-border-radius : 50%; -moz-border-radius :

    50%; -ms-border-radius : 50%; -o-border-radius : 50%; border-radius : 50%; } #noob #noob #old #old
  27. ❶ PRÉFIXES CONSTRUCTEURS border-radius, text-shadow, box-shadow, opacity non → box-sizing

    uniquement -moz- → transition, animation, gradients, calc() uniquement -webkit- → transform -webkit- et -ms- → shouldiprefix.com
  28. ❶ PRÉFIXES CONSTRUCTEURS border-radius, text-shadow, box-shadow, opacity non → box-sizing

    uniquement -moz- → transition, animation, gradients, calc() uniquement -webkit- → transform -webkit- et -ms- → flexbox → shouldiprefix.com Oui bon OK, là c'est vraiment le #¶§*¿!
  29. ❶ Explorons d'autres positionnements Adoptons box-sizing Employons des sélecteurs «

    avancés » Laissons-tomber (certains) préfixes BOUSCULONS NOS TECHNIQUES En résumé...
  30. FRAMEWORKS HTML / CSS Ce que propose un framework ❷

    Un Reset CSS Une base réutilisable Des grilles Des boutons Des tableaux Du Responsive ...
  31. PRÉPROCESSEURS CSS Des variables en CSS ❷ @basefont : 1em;

    @largescreen : 1280px; body { font-size: @basefont + .2em; } @media (min-width : @largescreen) { body {width: auto;} } body { font-size: 1.2em; } @media (min-width : 1280px) { body {width: auto;} } styles.less styles.css
  32. PRÉPROCESSEURS CSS Une notation imbriquée ❷ styles.less styles.css .sidebar a

    { color: tomato; &:hover, &:focus, &:active {text-decoration: underline;} } .sidebar a { color: tomato; } .sidebar a:hover, .sidebar a:focus, .sidebar a:active { text-decoration: underline; }
  33. PRÉPROCESSEURS CSS Des calculs et des « fonctions » ❷

    styles.less styles.css p { .em(20px); } div { .em(18px); } p { font-size: 1.4286em; } div { font-size: 1.2857em; } @basefont: 14px; .em(@size, @bf: @basefont){ @em: round((@size / @bf),4); font-size: unit(@em, em); }
  34. @column-width: 60; @gutter-width: 20; @columns: 12; header { .column(12); }

    article { .column(9); } aside { .column(3); } @media (max-device-width: 960px) { article { .column(12); } aside { .column(12); } } <header>...</header> <article>...</article> <aside>...</aside> PRÉPROCESSEURS CSS Des modèles de grilles et gouttières ❷ HTML LESS http://semantic.gs
  35. PRÉPROCESSEURS CSS Contribuent à la maintenance d'un projet ❷ Feuilles

    de styles allégées en développement, Maintenance et compréhension facilitées, Automatisation de tâches (préfixes, calculs, minification, etc.).
  36. utilisons des frameworks passons par des préprocesseurs BOUSCULONS NOS OUTILS

    En résumé... ❷ un peu Bien ! (si pré-requis préalables)
  37. ❸ Convention HTML / CSS / JS Conventions de langue

    (français / anglais) Conventions de syntaxe (espace / indentation) Conventions de commentaires (@TODO) Conventions de séparateur (trait d'union, underscore) Conventions de casse (minuscule, majuscule, CamelCase) Etc. AYEZ DES CONVENTIONS ! Ne recommencez jamais à zéro !
  38. ❸ Google HTML / CSS style guide GitHub CSS styleguide

    GitHub JavaScript styleguide WordPress CSS coding standards WordPress HTML coding standards WordPress JavaScript coding standards Idiomatic CSS AYEZ DES CONVENTIONS ! Faites votre choix !
  39. LE « CAS » INTERNET EXPLORER ❸ Internet Explorer, c'est

    de la *** – quelqu'un “ « Optimisé pour Internet Explorer » – un vieux site web “ Faites-moi un site compatible Internet Explorer ! – un client “
  40. LE « CAS » INTERNET EXPLORER ❸ IE... c'est plus

    ce que c'était ! ... «compatible» IE ? (#really?)
  41. ID ou CLASS ? ❸ Les « id » c'est

    pour des éléments uniques dans la page – quelqu'un qui n'a pas tort “ Les « class » c'est pour des éléments qui ne sont pas uniques – quelqu'un d'autre “ Don't use id selectors in CSS – CSSlint “
  42. Photo : Pizza Hut * > + ~ element /

    pseudo class / pseudo / [attr] ID style="..." !important Spécificité des sélecteurs CSS
  43. Photo : Pizza Hut * > + ~ element /

    pseudo class / pseudo / [attr] ID style="..." !important Spécificité des sélecteurs CSS
  44. ID ou CLASS ? ❸ Les id peuvent être nécessaires

    en HTML (ancres, formulaires, nommage, JavaScript) Un élément unique ne doit pas forcément être nommé par un id Un id n'est pas réutilisable Un id a une forte spécificité Montage : @geoffrey_crofte
  45. ID ou CLASS ? <ul id=″first″> <li><a>...</a></li> <li><a>...</a></li> <li><a>...</a></li> </ul>

    #first a { background: orange ; } #second a { background: white ; } ❸
  46. ID ou CLASS ? <ul id=″first″> <li><a>...</a></li> <li><a>...</a></li> <li><a>...</a></li> </ul>

    #first a { background: orange ; } #second a { background: white ; } a:hover, a:active, a:focus { background: green; } ? ❸
  47. ID ou CLASS ? <ul id=″first″> <li><a>...</a></li> <li><a>...</a></li> <li><a>...</a></li> </ul>

    #first a { background: orange ; } #second a { background: white ; } #first a:hover, #first a:active, #first a:focus, #second a:hover, #second a:active, #second a:focus { background: green ; } ❸
  48. ID ou CLASS ? <ul id=″first″> <li><a>...</a></li> <li><a>...</a></li> <li><a>...</a></li> </ul>

    #first a { background: orange ; } #second a { background: white ; } ❸ a:hover, a:active, a:focus { background: green !important; }
  49. ID ou CLASS ? <ul class=″first″> <li><a>...</a></li> <li><a>...</a></li> <li><a>...</a></li> </ul>

    .first a { background: orange ; } .second a { background: white ; } ❸ a:hover, a:active, a:focus { background: green; }
  50. ID ou CLASS ? <ul id=″first″> <li><a>...</a></li> <li><a>...</a></li> <li><a>...</a></li> </ul>

    [id=first] a { background: orange ; } [id=second] a { background: white ; } ❸ a:hover, a:active, a:focus { background: green; }
  51. CSS « OBJETS » ❸ #header { truc: machin; }

    #sidebar { truc: machin; } #main { truc: machin; } #footer { truc: machin; }
  52. #main { truc: machin; } #main .news { truc: machin;

    } #main #alaune .news { truc: machin; } CSS « OBJETS » ❸ #sidebar #edito { truc: machin; } #sidebar .afp { truc: machin; } #sidebar .ads { truc: machin; }
  53. #main { truc: machin; } #main .news { truc: machin;

    } #main #alaune .news { truc: machin; } CSS « OBJETS » ❸ #sidebar #edito { truc: machin; } #sidebar .afp { truc: machin; } #sidebar .ads { truc: machin; }
  54. #main { truc: machin; } #main .news { truc: machin;

    } #main #alaune .news { truc: machin; } CSS « OBJETS » ❸ #sidebar #edito { truc: machin; } #sidebar .afp { truc: machin; } #sidebar .ads { truc: machin; }
  55. CSS « OBJETS » ❸ ✔ Largeur adaptable (fluide) ✔

    Doit contenir les flottants ✔ Peut contenir une image (à gauche, largeur inconnue) Similarités :
  56. CSS « OBJETS » ❸ ✔ Largeur adaptable (fluide) ✔

    Doit contenir les flottants ✔ Peut contenir une image (à gauche, largeur inconnue) Similarités : .mod
  57. CSS « OBJETS » ❸ ✔ Largeur adaptable (fluide) ✔

    Doit contenir les flottants ✔ Peut contenir une image (à gauche, largeur inconnue) Similarités : .mod img .inner
  58. CSS « OBJETS » ❸ ✔ Largeur adaptable (fluide) ✔

    Doit contenir les flottants ✔ Peut contenir une image (à gauche, largeur inconnue) Similarités : .mod img .inner .mod > img { float: left; } .mod > .inner { float: left; width: ?!?!; }
  59. CSS « OBJETS » ❸ ✔ Largeur adaptable (fluide) ✔

    Doit contenir les flottants ✔ Peut contenir une image (à gauche, largeur inconnue) Similarités : .mod img .inner .mod > img { float: left; } .mod > .inner { margin-left: ?!?!; }
  60. CSS « OBJETS » ❸ parent float parent float Block

    Formatting Context parent {overflow : hidden;}
  61. CSS « OBJETS » ❸ frère float frère float Block

    Formatting Context frère {overflow : hidden;} dont le contenu s'écoule autour du flottant dont le contenu ne s'écoule plus autour du flottant
  62. CSS « OBJETS » ❸ .mod { overflow: hidden; }

    .mod > img { float: left; } .mod > .inner { overflow: hidden; }
  63. CSS « OBJETS » ❸ <div id="wrapper" class="line w80"></div> <section

    class="info mod pr0"></section> <nav id="navigation" role="navigation" class="large-no-float"> Des classes « sémantiques » ?! Privilégiez le sens et la fonction des éléments ! (les classes « visuelles » doivent être secondaires)
  64. CSS « OBJETS » ❸ OOCSS Nicole Sullivan SMACSS Jonathan

    Snooks http://oocss.org http://smacss.com/
  65. Ayons des conventions ! Reconsidérons (doucement) Internet Explorer Évitons les

    sélecteurs id si possible Appliquons des CSS « objets » (OOCSS) BOUSCULONS NOS MÉTHODES En résumé... ❸
  66. MERCI, À LA PROCHAINE ! Polices : Delicious heavy Annie

    Use Your Telescope Pictos : Design Bolts Capital18 Artua Raphaël Goetter www.alsacreations.fr @goetter