$30 off During Our Annual Pro Sale. View Details »

Web Trends to 2015

othree
October 22, 2015

Web Trends to 2015

othree

October 22, 2015
Tweet

More Decks by othree

Other Decks in Technology

Transcript

  1. Web Trend
    Course 6

    View Slide

  2. 1998

    View Slide

  3. View Slide

  4. View Slide

  5. View Slide

  6. 1999

    View Slide

  7. View Slide

  8. View Slide

  9. View Slide

  10. 2001

    View Slide

  11. View Slide

  12. 2002

    View Slide

  13. View Slide

  14. View Slide

  15. 2003

    View Slide

  16. View Slide

  17. View Slide

  18. View Slide

  19. View Slide

  20. 2002

    View Slide

  21. 2000

    View Slide

  22. View Slide

  23. View Slide

  24. View Slide

  25. 2004

    View Slide

  26. View Slide

  27. View Slide

  28. View Slide

  29. View Slide

  30. View Slide

  31. View Slide

  32. Web Hypertext Application
    Technology Working Group

    View Slide

  33. 2005

    View Slide

  34. View Slide

  35. View Slide

  36. View Slide

  37. View Slide

  38. RESTful API

    View Slide

  39. ORM

    View Slide

  40. CSRF token
    name="csrf-param" />

    View Slide

  41. Unobtrusive JavaScript
    • Separation of functionality (the "behavior layer")
    from a Web page's structure/content and
    presentation

    View Slide

  42. Asset Pipeline
    • All together assets pack system
    • JS, CSS, images, html
    • Concat, minimize, hashize, update file name

    View Slide

  43. View Slide

  44. View Slide

  45. View Slide

  46. View Slide

  47. First pass by Safari

    View Slide

  48. 2006

    View Slide

  49. View Slide

  50. View Slide

  51. View Slide

  52. View Slide

  53. View Slide

  54. View Slide

  55. View Slide

  56. Nesting
    nav {
    ul {
    margin: 0;
    padding: 0;
    list-style: none;
    }
    li { display: inline-block; }
    }

    View Slide

  57. Mixin
    @mixin border-radius($radius) {
    -webkit-border-radius: $radius;
    -moz-border-radius: $radius;
    -ms-border-radius: $radius;
    border-radius: $radius;
    }
    .box { @include border-radius(10px); }

    View Slide

  58. Variable
    $font-stack: Helvetica, sans-serif;
    $primary-color: #333;
    body {
    font: 100% $font-stack;
    color: $primary-color;
    }

    View Slide

  59. JSmin

    View Slide

  60. 2007

    View Slide

  61. View Slide

  62. View Slide

  63. View Slide

  64. iPhone
    first smart phone

    View Slide

  65. View Slide

  66. 2008

    View Slide

  67. View Slide

  68. HTC G1
    first android phone

    View Slide

  69. View Slide

  70. View Slide

  71. View Slide

  72. V8 JavaScript Engine
    • by Google
    • Starts the browser speed race

    View Slide

  73. yuicompressor

    View Slide

  74. View Slide

  75. View Slide

  76. First pass by Webkit

    View Slide

  77. canvas

    View Slide

  78. function draw() {
    var canvas = document.getElementById('canvas');
    if (canvas.getContext){
    var ctx = canvas.getContext('2d');
    ctx.beginPath();
    ctx.moveTo(75,50);
    ctx.lineTo(100,75);
    ctx.lineTo(100,25);
    ctx.fill();
    }
    }
    https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Tutorial/Drawing_shape

    View Slide

  79. View Slide

  80. function draw() {
    var canvas = document.getElementById('canvas');
    if (canvas.getContext){
    var ctx = canvas.getContext('2d');
    // Quadratric curves example
    ctx.beginPath();
    ctx.moveTo(75,40);
    ctx.bezierCurveTo(75,37,70,25,50,25);
    ctx.bezierCurveTo(20,25,20,62.5,20,62.5);
    ctx.bezierCurveTo(20,80,40,102,75,120);
    ctx.bezierCurveTo(110,102,130,80,130,62.5);
    ctx.bezierCurveTo(130,62.5,130,25,100,25);
    ctx.bezierCurveTo(85,25,75,37,75,40);
    ctx.fill();
    }
    }
    https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Tutorial/Drawing_shape

    View Slide

  81. View Slide

  82. 2009

    View Slide

  83. Reference number
    ECMA-123:2009
    © Ecma International 2009
    ECMA-262
    5th Edition / December 2009
    ECMAScript Language
    Specification

    View Slide

  84. View Slide

  85. View Slide

  86. View Slide

  87. # Assignment:
    number = 42
    opposite = true
    # Conditions:
    number = -42 if opposite
    # Functions:
    square = (x) -> x * x

    View Slide

  88. # Objects:
    math =
    root: Math.sqrt
    square: square
    cube: (x) -> x * square x
    # Splats:
    race = (winner, runners...) ->
    print winner, runners
    # Existence:
    alert "I knew it!" if elvis?

    View Slide

  89. View Slide

  90. View Slide

  91. Closure Compiler

    View Slide

  92. View Slide

  93. 2010

    View Slide

  94. View Slide

  95. iPhone 4
    first retina display

    View Slide

  96. View Slide

  97. View Slide

  98. View Slide

  99. 1 Way Data Binding

    View Slide

  100. 2011

    View Slide

  101. Reference number
    ECMA-123:2009
    © Ecma International 2009
    ECMA-262
    5.1 Edition / June 2011
    ECMAScript Language
    Specification

    View Slide

  102. and First ES6 Draft

    View Slide

  103. View Slide

  104. View Slide

  105. View Slide

  106. AMD

    View Slide

  107. define(['jquery'] , function ($) {
    return function () {};
    });

    View Slide

  108. View Slide

  109. View Slide

  110. var greetings = require("./greetings.js");
    module.exports = "Bonjour";

    View Slide

  111. UMD

    View Slide

  112. (function (root, factory) {
    if (typeof define === 'function' && define.amd) {
    // AMD. Register as an anonymous module.
    define(['b'], factory);
    } else {
    // Browser globals
    root.amdWeb = factory(root.b);
    }
    }(this, function (b) {
    return {};
    }));

    View Slide

  113. View Slide

  114. 2 Way Data Binding

    View Slide

  115. UglifyJS

    View Slide

  116. View Slide

  117. View Slide

  118. View Slide

  119. View Slide

  120. Media Query

    View Slide

  121. 2012

    View Slide

  122. View Slide

  123. View Slide

  124. http://techreport.com/news/21037/doom-ported-to-firefox-using-javascript-htm

    View Slide

  125. View Slide

  126. View Slide

  127. View Slide

  128. Grunt
    Bower
    Yeoman

    View Slide

  129. View Slide

  130. View Slide

  131. UglifyJS 2

    View Slide

  132. View Slide

  133. View Slide

  134. View Slide

  135. View Slide

  136. 2013

    View Slide

  137. View Slide

  138. View Slide

  139. View Slide

  140. View Slide

  141. View Slide

  142. View Slide

  143. View Slide

  144. latitude="37.77493"
    longitude="-122.41942">

    View Slide












  145. View Slide

  146. View Slide

  147. http://creativejs.com/2013/06/the-race-for-speed-part-1-the-javascript-engine-family-tree/

    View Slide

  148. asm.js

    View Slide

  149. View Slide

  150. 2014

    View Slide

  151. View Slide

  152. ESLint

    View Slide

  153. View Slide

  154. View Slide

  155. View Slide

  156. View Slide

  157. 2015

    View Slide

  158. View Slide

  159. View Slide

  160. http://www.codekitchen.ca/visualizing-glimmer-performance

    View Slide

  161. Reference number
    ECMA-123:2009
    © Ecma International 2009
    ECMA-262
    6th Edition / June 2015
    ECMAScript® 2015
    Language Specification

    View Slide

  162. View Slide

  163. View Slide

  164. View Slide

  165. View Slide

  166. WebAssembly

    View Slide

  167. View Slide

  168. Relay
    • Use GraphQL to communicate with server
    • Try to replace RESTful API

    View Slide

  169. GraphQL
    {
    user(id: 3500401) {
    id,
    name,
    isViewerFriend,
    profilePicture(size: 50) {
    uri,
    width,
    height
    }
    }
    }

    View Slide

  170. View Slide