data:image/s3,"s3://crabby-images/3aa25/3aa25faa335825084a92d4a4168f33294075764a" alt=""
Evan You
An international team
data:image/s3,"s3://crabby-images/38644/38644971198dabf62e49cc129096fdd34cc3ac95" alt=""
data:image/s3,"s3://crabby-images/52fbf/52fbf53e3a5326e3fefa18d48c79e112b0db7136" alt=""
data:image/s3,"s3://crabby-images/dd5fe/dd5fe180b4d7840c0043d09c757fa45e25d84c74" alt=""
data:image/s3,"s3://crabby-images/e5ad4/e5ad4e5c7b388d1d396e3764daa0fed439334a6f" alt=""
data:image/s3,"s3://crabby-images/fd768/fd768314816edcc0f0ca4d87c6bc067f989a9e48" alt=""
Vue.js is the 3rd most starred project on Github
data:image/s3,"s3://crabby-images/62c65/62c65623421f5ba55f94f4d42e371570f165be3f" alt=""
data:image/s3,"s3://crabby-images/ae4dc/ae4dcb373ee5e24be5464117489bda754249f0e1" alt=""
data:image/s3,"s3://crabby-images/29fda/29fdab01cdcfdfd3b6a23bc744baf07d263d5428" alt=""
Github Stats, october 2018
data:image/s3,"s3://crabby-images/f0bca/f0bca934ed3f79f8aaf56e593baa6fd9757dfee3" alt=""
data:image/s3,"s3://crabby-images/baf76/baf7663ec68e510a864fd36b2962d7eacb270134" alt=""
data:image/s3,"s3://crabby-images/5f9d3/5f9d34e9b02b8e50e0f3bfa78ec93e9d15e82b82" alt=""
data:image/s3,"s3://crabby-images/87b74/87b746ef4004f9a5a081ddce66285c7dea246c4b" alt=""
React | Vue | Angular | |
---|---|---|---|
TypeScript ? | optional | optional | recommended |
JSX ? | recommended | optional | no |
Prog. style | functional | declarative | mix func/decl |
State management | centralized, immutable : flux, redux... |
internal, Vuex optional |
internal |
Ecosystem | Rich++ community driven not self-sufficient |
Rich some official libs ; promote other 3rd party solutions |
Rich mostly official try to be all-in-one, self-sufficient |
data:image/s3,"s3://crabby-images/74bdf/74bdf805f4b55a622d0bfce3388904275397bd89" alt=""
data:image/s3,"s3://crabby-images/bb1de/bb1de65706a79a7460afc9eb8d29741395532f82" alt=""
- Do one thing,
do it well - Not for everyone
- Innovative, disruptive
- Bring your tools and spare parts
- Accessible, easy
- Familiar to use
- Quickly efficient, can slow down
with time - Quite common,
but can be tuned
- Fully equipped
- Heavyweight
- Slower to start, more efficient
with time - Spare parts hard to find out there
What is the best JS framework ?
data:image/s3,"s3://crabby-images/d984b/d984bd3f2a314468d1e5c1b0d546073ac7edd946" alt=""
data:image/s3,"s3://crabby-images/85cab/85cab82afda3d23acb89d1ee64170af81493c1fe" alt=""
data:image/s3,"s3://crabby-images/3824d/3824d71a2742d86dde89d9efa78abc81a2922dcf" alt=""
data:image/s3,"s3://crabby-images/7e45c/7e45c816e985766a91b8bf5358b6069567fc8f26" alt=""
data:image/s3,"s3://crabby-images/a449c/a449cc8526b09c0c53c7f42e5bc1aeef904d9c99" alt=""
How does it work ?
getters/setters (ES5)
let _name = "joe";
const user = {
get name() {
console.log("accès en lecture à la propriété")
return _name
},
set name(value) {
console.log("accès en écriture à la propriété")
_name = value
}
}
data:image/s3,"s3://crabby-images/5efde/5efde3a53866830e5fe3f2491cca856d17efdd1e" alt=""
How does it work ?
Next in Vue 3 : Proxy (ES6)
const _user = { name: "joe" }
const user = new Proxy(_user, {
get(obj, key) {
console.log(`accès en lecture à la propriété ${key}`)
return Reflect.get(obj, key)
},
set (obj, key, value) {
console.log(`accès en écriture à la propriété ${key}
avec la valeur ${value}`)
return Reflect.set(obj, key, value)
}
})
Vue Reactivity System
data:image/s3,"s3://crabby-images/88a50/88a50b453deafa6a059596312feeca5e74754ed8" alt=""
- AngularJS 1.x : synchronous dirty-checking
- Angular 2+ : Zones (~= async dirty-checking)
-
React : manual updates (setState)
manual optimizations (shouldComponentUpdate)
diff against a Virtual DOM to optimize rendering
- Vue : auto updates (setters / proxies)
auto optimization (dependency tracking)
diff against a Virtual DOM
Comparing data-binding and change detection
between frameworks
En savoir plus
data:image/s3,"s3://crabby-images/35643/356437499e6c20187462c5ae2db623834c3ea709" alt=""
Syntax overview
Templates
data:image/s3,"s3://crabby-images/8da59/8da59f106e6944c4363f546bdbdd2acde9d73275" alt=""
v-if , v-else, v-else-if
Directives
data:image/s3,"s3://crabby-images/7b091/7b0911c9728cb42c23fb56050c752abf5795cc84" alt=""
v-for
Directives
data:image/s3,"s3://crabby-images/04328/043288060c8d2850988057c2c06c12c19b26b978" alt=""
data:image/s3,"s3://crabby-images/4c05d/4c05d5959f867f71f690cb6276abb7de0fe8ec60" alt=""
Declaring components
Communication between components
data:image/s3,"s3://crabby-images/feea1/feea1f8569fec2bf857b56c642cdd04dcee62398" alt=""
Computed props and watchers
data:image/s3,"s3://crabby-images/b84fe/b84fe16ae5630ece8096baab6d67acef833b8839" alt=""
Vue Cheat Sheet
data:image/s3,"s3://crabby-images/cad90/cad906d59fc14c47b70823f47dd84b769ba62189" alt=""
data:image/s3,"s3://crabby-images/7f3e2/7f3e23f416fbc57e8d354baaf1d2a13932d94f04" alt=""
Single File Components
(*.vue)
Easily share and reuse components
Centralize code
and tooling
Simplify the use of alternative languages / preprocessors
Alternative, class-based syntax to use with Babel or TypeScript
Will be officially supported in Vue 3
data:image/s3,"s3://crabby-images/eff6d/eff6dbbefca177536a74a6f1a4b93855a655005b" alt=""
data:image/s3,"s3://crabby-images/9a6e6/9a6e650f630fcada53d991967351e32c6e32d426" alt=""
Vue CLI, Vue UI
Modularity
+
Flexibility
+
Easy to start and integrate,
progressive learning and tooling
+
focus on community
=
Giant ecosystem
https://github.com/vuejs/awesome-vue
Vue@Worldline
PWA La Banque Postale, Jessy Archiles & Yann Perthuis:
very easy to start, for everyone
very happy with Vue for our PWAlightweight but less complete than Angular
ewLabs, Arnaud Berthillot:
easiest learning curve, good documentation
quickly adopted and loved by the community
adapted for small to medium web projects
SDCO: used in 3 projects currently in development
Coming soon: a 1-day training session for Vue.js by SDCO
- Simple: small API surface, you can start in 2 hours
- Lightweight: 20kb .min.gzip runtime
- Versatile: can be used with almost any stack
- Stable and mature, rich ecosystem
- Takes the best ideas from competitors
- Almost no API breaking changes in 4 years
To sum up
Vue is also great to make games
Bonus slide
data:image/s3,"s3://crabby-images/02910/02910b331da0e54830d0f39ee5feb2a9176d5530" alt=""
data:image/s3,"s3://crabby-images/3e85c/3e85cdb5fb42055d8862d1e4f0e274a4ee53defe" alt=""
data:image/s3,"s3://crabby-images/52aa9/52aa96ebcae26ff81a1467d1c90f41efa42e5f68" alt=""
data:image/s3,"s3://crabby-images/5b3fc/5b3fc570cb505b978d4065e81a8d807de7ccd2a3" alt=""
Introduction à Vue.js - COTRECS octobre 2018
By sylvainpv
Introduction à Vue.js - COTRECS octobre 2018
Introduction à Vue.js - COTRECS octobre 2018
- 2,328