Oh no JavaScript: From jQuery to Hyperapp and Blazor?!
Vedran Mandić: MCSD, MCT, @vekzdran
ATD14, 2018-12-05
data:image/s3,"s3://crabby-images/afa9b/afa9b90af6efc7a6d4529c45fe12e9a252c2707b" alt=""
data:image/s3,"s3://crabby-images/6f119/6f1195389c98a79e3aec9a9d4a5350a7dc74df0c" alt=""
data:image/s3,"s3://crabby-images/cf5f5/cf5f56319a9ad8458643ef211e4c1f0b4e213bb0" alt=""
1993., NCSA Mosaic, HTML processor, browsing documents
So web dev is (was?) boring to you?
data:image/s3,"s3://crabby-images/2793a/2793a25b9a7d16fb3c6cac42ed45d6d0425b69b7" alt=""
Mocha/JavaScript - Sept 1995, released on 3rd of Dec 1995
data:image/s3,"s3://crabby-images/6786d/6786d056fa9eff6ad1fc61784aeeac3893c40954" alt=""
1996., Netscape Navigator 3, HTML, CSS, JavaScript!
Netscape implemented CSS internally by translating CSS rules into snippets of JavaScript 🔥, which were then run along with other scripts 🔥🔥.
Ah, hello dar... ling my old friend!
data:image/s3,"s3://crabby-images/c43c0/c43c0209b3582c75bc3652114e313fa807336bcb" alt=""
MS Internet Explorer, HTML, CSS, JavaScript, genius quirks etc
data:image/s3,"s3://crabby-images/d681a/d681ae836479181dcdc80bc57a7e8908c5fd6c44" alt=""
data:image/s3,"s3://crabby-images/67ebf/67ebff809b13a9a7e035ac04683f3b0fbf5356b9" alt=""
Remember me? 🙈⚡
$ === "Advanced JS"; // jQuery
$(".gumb").on("click", function() {
$(".loader").show();
$.ajax({
url: "/api/dajVrijeme",
data: {
zipcode: 10020
},
success: function(result) {
$("#vrijeme-temp")
.html("<strong>" + result + "</strong> C*";
$(".loader").hide();
}
});
});
data:image/s3,"s3://crabby-images/ff1f1/ff1f1083e26898fbdce9f2b1614ed99e3982f462" alt=""
...the internet grows content/dev heavy
total bs if you ask me, devs just got "smart" new ideas
jk, the struggle is real, hint: see next slide :-)
data:image/s3,"s3://crabby-images/bbe34/bbe34c7244e76a42a366a1e22668d47bd97d34b4" alt=""
Facebook 2018, init load: 263 requests, 9.1 MB transferred
Problem much?
- Web sites are turning into Web apps, SPAs
- Code complexity grows as the site gets bigger
- Assembly gets more interdependent
- Devs want discrete JS files / modules
- Deployment optimized code? Fewer HTTP calls?
data:image/s3,"s3://crabby-images/2793a/2793a25b9a7d16fb3c6cac42ed45d6d0425b69b7" alt=""
data:image/s3,"s3://crabby-images/2793a/2793a25b9a7d16fb3c6cac42ed45d6d0425b69b7" alt=""
data:image/s3,"s3://crabby-images/c1f9e/c1f9e44f577b64b10beea8a49e697ce7b7283298" alt=""
Enter modular front-end
define(function (require) {
var $ = require('jquery'),
lib = require('./lib'),
controller = require('./controller/c2'),
model = require('./model/m2');
//A fabricated API to show interaction of
//common and specific pieces.
controller.setModel(model);
$(function () {
controller.render(lib.getBody());
});
});
...and then "it" starts, around 2009:
Knockout, Node, npm, Backbone, AngularJS, ECMAScript, Babel, React, Webpack, TypeScript, Angular, Hyperapp, Elm, ReasonML, Fabel, WebAssembly, Blazor...
data:image/s3,"s3://crabby-images/641a0/641a0e3ccda2402d4b250c62f5628d471c52a9a6" alt=""
Well... I think this sums it up a bit? :)
Agenda (not just Hyperapp)
Some history ⚔️ on all of this pain...- State of JS (2018)
- How it's done today? 👨💻
- A look 👀 into HyperappJS
- Demo ⚙️
- Q&A
40 min talk with interactive demos
"State" of JS Oct 2018, n = 19k devs
TL;DR: React wins the internet
data:image/s3,"s3://crabby-images/e67de/e67de8a8bbc5dd0dbfa1e92f07717689414121b3" alt=""
State of the JS State Management
TL;DR: Redux wins the state
data:image/s3,"s3://crabby-images/31c33/31c338a60cfab67c2203faec6d417580344971a2" alt=""
BTW where is Hyperapp?
data:image/s3,"s3://crabby-images/951bf/951bffceb6bbb499dce2efda30c368ae5df21e13" alt=""
So, how to dev FE today?
Sorry, no magic bullet... 🤠
It is really a mix, you know it, and differs from team to team.
Better learn how it all interconnects! ⚡
{ } // hello I am your legitimate global state object ;)
Is it "easy"? How to cope?
Where is the value 💰 in it?
Should we go React + Redux or Vue + Vuex?
Does the client / boss even care? 🤡
Meet HyperappJS
A model-view-update Elm inspired FE/UI dev 1 kB lib
data:image/s3,"s3://crabby-images/afa9b/afa9b90af6efc7a6d4529c45fe12e9a252c2707b" alt=""
data:image/s3,"s3://crabby-images/40cf5/40cf5c0680d8969692480643daef42539fae3b77" alt=""
const view = function(state, actions) { ... };
The big idea? 💡
Model-View-Update step by step: http://meiosis.js.org/
The mother of examples... "Hello World" app
import { app, h } from "hyperapp";
// your data "model"
const state = {
message: "Hello World!"
};
// your JSX HTML markup UI
const view = (state) => {
return (
<div>{state.message}</div>
);
};
// run the app!
app(state, null, view, document.getElementById("root"));
The never dying interview example... a counter app! 😜
What is life without some
side-effects? 🤔
Why Hyperapp? 🚀
- learn and understand model-view-update design
- small 1 kB, easy setup with Webpack, Parcel or Rollup
- has its own vDOM - h
- async actions do not cause rerendering
- super quick to learn and use
- supports lifecycle events which are vDOM events
- transfer to React with more ease
- Redux won't scare you next time... :-)
- cherish the unidirectional binding flow
Demo ⚙️ setup with Parcel ✨ module boundler
Morals of the story 👾
- think about maintainabilty and team first
- do not hesitate to try new patterns and technology
- JSX is here to stay, so is vDOM technology, embrace it
- unidirectional flow is predictable and less prone to error
- React and Webpack are a safe-play
- do not be afraid of the learning curve, invest!
- nourish a software craftsmanship culture
- SPAs are not magic-bullets!!!
The end! 📸 Questions?
data:image/s3,"s3://crabby-images/30368/3036863515508bd881d1e488f4bbc12afa058d48" alt=""
VEDRAN MANDIĆ
mandic.vedran@gmail.com
@vekzdran @vmandic
Oh no JavaScript: From jQuery to Hyperapp?!
By Vedran Mandić
Oh no JavaScript: From jQuery to Hyperapp?!
A short presentation about a Front-End JS development history and a dev library HyperappJS for everyone with doubts in all the other development libraries and frameworks.
- 1,749