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

Leveling Up Your Front-end skills

Yuya Saito
January 25, 2014

Leveling Up Your Front-end skills

Yuya Saito

January 25, 2014
Tweet

More Decks by Yuya Saito

Other Decks in Programming

Transcript

  1. Leveling Up
    Front-end Skills
    Yuya Saito @ Frontrend in Fukuoka
    #frontrend_ff

    View Slide

  2. View Slide

  3. Hands On
    Multi Tracks &

    View Slide

  4. Yuya Saito
    Frontend Developer
    @ CyberAgent

    View Slide

  5. View Slide

  6. View Slide

  7. Agenda
    Front-end Development is Easy!?
    ϑϩϯτΤϯυ։ൃ͸؆୯
    No, it’s not!
    ϑϩϯτΤϯυ
    ɾ
    εΩϧΛϨϕϧΞοϓ͠Α͏
    There are actually more…
    ͞ΒͳΔਂ෵΁ʜ
    How to learn all this?
    ϑϩϯτΤϯυ
    ɾ
    εΩϧͷֶͼํ

    View Slide

  8. Front-end
    Development is
    Easy!?
    ϑϩϯτΤϯυ։ൃ͸؆୯

    View Slide

  9. ͭͷڞ௨఺͕͋Δ
    HTML, CSS & JavaScript

    View Slide

  10. ͷߴ͞
    Learnability

    View Slide

  11. WWW is Only
    20 Years Old

    View Slide

  12. HTML

    View Slide

  13. < >
    TAG NAME

    View Slide

  14. TAG NAME
    About 100 of

    View Slide

  15. CSS

    View Slide

  16. selector {
    property: value;
    }

    View Slide

  17. selector {
    color: red;
    }

    View Slide

  18. JavaScript

    View Slide

  19. JavaScript
    ͸؆୯Ͱ͸ͳ͍ͷͰ͸

    View Slide

  20. function
    if var for {}
    while []
    try {} catch (e) {}

    View Slide

  21. JavaScript
    ͸γϯϓϧͰ׮༰ͳݴޠ

    View Slide

  22. JavaScript
    ͸ϒϥ΢β͑͋͞Ε͹࣮ߦͰ͖Δ

    View Slide

  23. Learnability
    ͕ٕज़ͷ޿͕ΓΛੜΈग़ͨ͠ɻ

    View Slide

  24. No, it’s not!
    ϨϕϧΞοϓ͠Α͏
    ϑϩϯτΤϯυ
    ɾ
    εΩϧΛ

    View Slide

  25. View Slide

  26. ϒϥ΢βͷ಺෦ߏ଄Λ஌Δ
    Browser
    Learn:

    View Slide

  27. Browser͸։ൃ؀ڥ

    View Slide

  28. Browser͸ϓϥοτϑΥʔϜ

    View Slide

  29. Browser͸ιϑτ΢ΣΞ

    View Slide

  30. html5rocks.com/en/tutorials/internals/howbrowserswork

    View Slide

  31. Google Chrome Developer Relations
    Paul Irish

    View Slide


  32. As a web developer, learning the internals of
    browser operations helps you make better
    decisions and know the justifications behind
    development best practices.
    While this is a rather lengthy document, we
    recommend you spend some time
    digging in; we guarantee you'll be glad you
    did.
    - Paul Irish

    View Slide


  33. ϒϥ΢β಺෦ͷಇ͖ΛֶͿࣄ͸
    8FC։ൃऀʹͱͬͯΑΓΑ͍ղܾΛߦ͏͜ͱɺ
    ͦͯ͠։ൃʹ͓͚ΔϕετϓϥΫςΟεͷഎޙʹ͋Δ
    ࠜڌΛཧղ͢Δ͜ͱʹͭͳ͕Γ·͢ɻ
    ͜ͷهࣄ͸௕͍΋ͷͰ͸͋Γ·͕͢ɺ
    গ࣌ؒ͠Λׂ͍ͯಡΜͰΈ͍ͯͩ͘͞ɻ
    ͦͷ͕࣌ؒແବʹͳΒͳ͍͜ͱ͸อূ͠·͢ɻ
    - Paul Irish

    View Slide

  34. chromium.org/developers/design-documents/gpu-accelerated-compositing-in-chrome

    View Slide

  35. ۜͷ஄ؙ͸ଘࡏ͠ͳ͍ɻ
    ͔͠͠஄ؙͦͷ΋ͷ͸ଘࡏ͍ͯ͠Δɻ
    ஄ؙͷબͼํΛֶͿ͜ͱ͕େ੾ɻ
    Learn:

    View Slide

  36. ߏ଄΍ઃܭͷํ๏Λ஌Δ
    JavaScript
    Learn:

    View Slide

  37. jQuery͚ͩͰ͸΋͸΍े෼Ͱ͸ͳ͍ɻ
    Not Just jQuery

    View Slide

  38. jQuery͸ͲΜͳ໰୊Λղܾ͠Α͏ͱ
    What jQuery is?
    ͍ͯ͠Δͷ͔

    View Slide

  39. JavaScriptʹ͓͚ΔΞϓϦͷઃܭ
    Architecture

    View Slide

  40. ໾ׂ෼୲ΛͲ͏෼཭ɾ݁߹͢Δͷ͔
    MV*

    View Slide

  41. Backbone.js
    Angular.js
    Ember.js
    ͦΕͧΕʹར఺ͱܽ఺͕͋Δɻ

    View Slide

  42. ίϝϯτΛؚΊͯ΋1,600ߦఔ౓
    Read: Backbone.js

    View Slide

  43. TODOΞϓϦҎ֎ͷαϯϓϧΛ
    ࡞ͬͯΈΔɻ
    with Backbone.js

    View Slide

  44. Angular.jsͰॻ͖׵͑ͯΈΔɻ

    View Slide

  45. MV*͕ͲΜͳ໰୊Λ
    ղܾ͠Α͏ͱ͍ͯ͠Δͷ͔
    Learn:

    View Slide

  46. Fail Fast
    Fail Often

    View Slide

  47. ߏ଄΍ઃܭͷํ๏Λ஌Δ
    CSS
    Learn:

    View Slide

  48. CSS:
    Style
    Layout
    Animation

    View Slide

  49. CSS needs
    Architecture, too
    ͦͷͨΊͷػೳ͸ଘࡏ͠ͳ͍ͱ͍͏ໃ६

    View Slide

  50. Learn:
    CSS Preprocessor

    View Slide

  51. CSS Preprocessor
    Learn:
    Doesn’t Solve it!
    CSSͷઃܭΛ༰қʹͯ͘͠ΕͨΓ͸͠ͳ͍

    View Slide

  52. OOCSS
    SMACSS
    BEM
    by Nicole Sullivan
    by Jonathan Snook
    by Yandex

    View Slide

  53. They’re just
    An Example.
    ͜ΕΒͷํ๏࿦͸͋͘·Ͱ΋ྫɻ

    View Slide

  54. ͳΜͲ΋܁Γฦ͞ΕΔɺ
    ͋Δ͍͸܁Γฦ͢͜ͱ͕Ͱ͖Δɺ
    ύλʔϯΛͲͷΑ͏ʹ
    ൃݟ͠ɺ
    ࣮૷͠ɺ
    ໋໊͢Δͷ͔ɻ

    View Slide

  55. by ୩ ୓थ
    15:30~ @ ձٞࣨ5
    Goal of Better
    CSS Architecture

    View Slide

  56. youtu.be/BlSFXdnuq5E

    View Slide

  57. Modularity
    Learn:
    ϞδϡϥʔԽΛ஌Δ

    View Slide

  58. More Than
    A Few Thousand
    Lines of Codes
    ਺ઍߦʹ΋ٴͿίʔυ΋௝͘͠ͳ͍ɻ

    View Slide

  59. ͳΜͷσβΠϯઃܭ΋ͳ͘ɺ
    ୯७ʹϑΝΠϧΛ෼ׂͯ͠࡞ۀΛߦ͑͹
    ϖʔδϩʔυͷ࠷దԽͷجຊݪଇͰ͋Δɺ
    HTTPϦΫΤετΛ
    ૿΍͢͜ͱʹͳͬͯ͠·͏ɻ

    View Slide

  60. CSSͳΒ·ͩ͠΋ɺ
    JavaScriptʹ͸ղফ͠ͳ͚Ε͹ͳΒͳ͍
    ґଘؔ܎΋࣮֬ʹଘࡏ͢ΔͰ͠ΐ͏ɻ

    View Slide

  61. Modular Design

    View Slide

  62. View Slide

  63. Module Design
    JavaScriptʹ΋CSSʹ΋ݱ࣌఺Ͱ͸
    ͜ͷϒϩοΫ޻๏Λ࣮ݱ͢ΔͨΊͷ
    ػೳ͸ݴޠͱͯ͠༻ҙ͞Ε͍ͯͳ͍ɻ

    View Slide

  64. There are
    Tools (a lot)

    View Slide

  65. Require.js
    by James Burke

    View Slide

  66. Learn:
    Asynchronous
    Module
    Definition

    View Slide

  67. Require.js
    is Good But...
    Require.jsʹ΋໰୊͸͋Δ...

    View Slide

  68. Node.js
    IS JavaScript
    But...
    Node.jsͰ͸ฉ͔ͳ͍໰୊...?

    View Slide

  69. CommonJS

    View Slide

  70. Browserify.js
    by James Holiday AKA substack

    View Slide

  71. ES6
    import / export

    View Slide

  72. CSS?

    View Slide

  73. Testing
    Learn:
    ϢχοτςετΛ஌Δ

    View Slide

  74. Linting is
    First Step to Test
    ·ͣLint͔Β࢝ΊΔ

    View Slide

  75. ࣗ৴Λ࣋ͬͯؒҧ͍Λਖ਼͢
    ϫʔΫϑϩʔΛ࣋ͭɻ

    View Slide

  76. Refactoring

    View Slide

  77. Learn:
    Jasmine
    Mocha
    or

    View Slide

  78. CSS?

    View Slide

  79. CSS needs Testing

    View Slide

  80. Not Yet

    View Slide

  81. speakerdeck.com/studiomohawk/testable-javascript

    View Slide

  82. speakerdeck.com/studiomohawk/unit-testing-with-jasmine

    View Slide

  83. Performance
    Learn:
    ύϑΥʔϚϯεΛ஌Δ

    View Slide

  84. ύϑΥʔϚϯε͸ػೳ

    View Slide

  85. Tools, not Rules.
    - Paul Lewis

    View Slide

  86. ϕετ͕ৗʹϕετͱ͸ݶΒͳ͍ɻ

    View Slide

  87. -webkit-transform:
    translate3d(0,0,0);

    View Slide

  88. What we can measure,
    we can optimize!
    - Ilya Grigorik

    View Slide

  89. View Slide

  90. Network Panel

    View Slide

  91. Timeline Panel

    View Slide

  92. Profile Panel

    View Slide

  93. developers.google.com/chrome-developer-tools/

    View Slide

  94. There are
    actually more…
    ͞ΒͳΔਂ෵΁ʜ

    View Slide

  95. Quick Peek
    ͘͝؆୯ʹɻ

    View Slide

  96. Cross Brower
    Platform
    Device

    View Slide

  97. Test Early

    View Slide

  98. $49, Mac Only
    GhostLab

    View Slide

  99. github.com/shakyShane/browser-sync

    View Slide

  100. Progressive
    Enhancement

    View Slide

  101. ৗʹ৽͍ٕ͠ज़Λ࠾༻͢Δ͜ͱΛ
    ظ଴͞Εͳ͕Βɺ
    աڈͷϒϥ΢β΁ͷରԠΛഭΒΕΔໃ६ɻ

    View Slide

  102. Progressive Enhancement͸
    ϑϩϯτΤϯυ։ൃऀͷಠஃ৔ɻ

    View Slide

  103. ϒϥ΢β΍σόΠεͰ੍ݶΛ
    ߟ͑ΔͷͰ͸ͳ͘ɺ
    ίϯϙʔωϯτ୯ҐͰઓུΛߟ͑Δɻ

    View Slide

  104. !lamentgroup.com/lab/grade_components/

    View Slide

  105. Template

    View Slide

  106. HTMLΛͦͷ··هड़͢Δ͜ͱ͕
    ݮ͖͍ͬͯͯΔɻ

    View Slide

  107. No Choice on
    Server Side
    αʔόαΠυͷςϯϓϨʔτʹ͍ͭͯ͸
    զʑʹબ୒ࢶ͕༩͑ΒΕΔ͜ͱ͸ͳ͍ɻ

    View Slide

  108. CMSΛؚΊͯɺ
    ϝδϟʔͳϑϨʔϜϫʔΫͰ
    ࠾༻͞Ε͍ͯΔςϯϓϨʔτݴޠʹ͍ͭͯ͸
    ͓֮͑ͯ͘΂͖ɻ

    View Slide

  109. Too Many on
    Client Side
    ΫϥΠΞϯταΠυʹ͸΋͸΍
    બ୒͢Δ͜ͱ͕೉͍͠΄Ͳଘࡏ͢Δɻ

    View Slide

  110. Handlebars.js
    Underscore.js

    View Slide

  111. Research

    View Slide

  112. Advocate for the Open Web
    Molly Holzschlag

    View Slide


  113. If you want to be doing the same things for
    the next 10 years, you're in the wrong job.
    - Molly Holzschlag

    View Slide


  114. ࣍ͷ೥ؒɺ
    ಉ͜͡ͱΛ͍͍ͯͨ͠ͱ
    ࢥ͏ͳΒɺ
    ͜ͷۀք͸޲͍͍ͯͳ͍ɻ
    - Molly Holzschlag

    View Slide

  115. Web will be
    always
    Changing.

    View Slide

  116. Inovation

    View Slide

  117. Self Learning

    View Slide

  118. Πϊϕʔγϣϯʹରͯ͠
    ৗʹහײͰ͋Γ͚ͭͮΔ͜ͱ͸
    ϑϩϯτΤϯυ։ൃऀͷ੹຿ɻ

    View Slide

  119. ৘ใऩू͸श׳Խ͕伴ɻ

    View Slide

  120. How to learn all
    this?
    ϑϩϯτΤϯυ
    ɾ
    εΩϧͷֶͼํ

    View Slide

  121. ֫ಘͰ͖Δͷ͔
    Ͳ͏ͨ͠Β͜ΕΒͷεΩϧΛ

    View Slide

  122. ਫ਼௨͍ͯ͠Δͷ͔
    ࢲࣗ਎͢΂ͯͷεΩϧʹ
    Better Question

    View Slide

  123. No.

    View Slide

  124. ͋Δ͸ͣͰ͢ɻ
    օ͞Μʹ΋ಘҙͳδϟϯϧ͸
    ूத͢Δ΂͖ɻ
    ·ͣ͸ͦ͜Λ৳͹͍ͯ͘͜͠ͱʹ

    View Slide

  125. T

    View Slide

  126. I

    View Slide

  127. View Slide

  128. View Slide

  129. ଞͷεΩϧʹֶ͍ͭͯͿඞཁੑ͕
    Կ͔ͭͷεΩϧΛਂߞ͢Δ্Ͱɺ
    ඞͣग़͖ͯ·͢ɻ

    View Slide

  130. View Slide

  131. View Slide

  132. Homework
    Կ͕ಘҙͳͷ͔
    Կʹڵຯ͕͋Δͷ͔

    View Slide

  133. What’s your Goal?

    View Slide

  134. Apple CEO
    Steve Jobs

    View Slide


  135. You can't connect the dots looking forward;
    you can only connect them looking
    backwards. So you have to trust that the
    dots will somehow connect in your future.
    - Steve Jobs

    View Slide


  136. ઌΛಡΜͰ఺ͱ఺Λͭͳ͙͜ͱ͸Ͱ͖·ͤΜɻ
    ޙ͔ΒৼΓฦͬͯॳΊͯͰ͖ΔͷͰ͢ɻ
    ͦΕΒͷ఺͸ඞͣͲ͔͜ͷະདྷͰ
    ͭͳ͕Δ͜ͱΛ৴͡ͳ͚Ε͹ͳΒͳ͍ͷͰ͢ɻ
    - Steve Jobs

    View Slide

  137. One More Thing...

    View Slide

  138. Ask Why,
    Not How.

    View Slide

  139. Thank You!
    Follow me @ cssradar

    View Slide