Écosystème web en 2021 :
welcome to the jungle
Vincent Ogloblinsky - @vogloblinsky
Orange Innovation - ARoD Team 🤘
Vincent Ogloblinsky
Compodoc maintainer
data:image/s3,"s3://crabby-images/5616c/5616c9c1e25d473d61188ed8ddb21e9e170056ed" alt=""
data:image/s3,"s3://crabby-images/0418d/0418d5e09e70603d9ab9344c44339fae54d84ea4" alt=""
data:image/s3,"s3://crabby-images/22f70/22f707aca05e1443f78599e9005cd76cff9a9358" alt=""
data:image/s3,"s3://crabby-images/9942e/9942ecc815dcca195189a6c52a951ec9d1aa0da9" alt=""
Google Developer Expert on Web Technologies
Software architect
Agenda
1.
Language(s)...
2.
Framework(s)...
3.
Outils
4.
APIs
Disclaimer
Oui c'est toujours le dawaa !
Mais c'est pareil dans d'autres domaines 😉
data:image/s3,"s3://crabby-images/8cfe5/8cfe5267a0c537725dd0013e333ef5b7ab1f15f9" alt=""
data:image/s3,"s3://crabby-images/6f9ea/6f9ea215da4f9d6f7bfe852e1f86c84200e8c8b0" alt=""
Languages
HTML 5.3
Web Content Accessibility Guidelines (WCAG) 2.2
autocapitalize attribute
defaultPlaybackRate attribute
decoding attribute for images
CSS
JavaScript
data:image/s3,"s3://crabby-images/9e2f1/9e2f177fe3702b8e520d71ee2567b3fec32d02d5" alt=""
JavaScript
ES MODULES everywhere : script tags & web workers !
ES2021 :
- Promise.any : // request, first win
- String.prototype.replaceAll : enfin !
- Logical Assignment Operators : a ??= b ===> a = a ?? (a = b)
- Numeric Separators : 1__000__000
- Intl.DisplayNames :
var currencyNames = new Intl.DisplayNames(['en'], {type: 'currency'});
console.log(currencyNames.of('USD')); // "US Dollar"
JavaScript
ES2022 :
- Class public and private fields - getter/setters
- Static class fields and private static methods
- Top-level await
const translationKeys = await import(`/i18n/${navigator.language}`);
Frameworks
Frameworks
data:image/s3,"s3://crabby-images/1bad6/1bad690d999878e3fbb7a86fc87e69f86dd74503" alt=""
Frameworks
Approche classique
Orchestrateurs de composants
Runtime du framework sur le poste client
Lockin fort...
Over-engineering de librairies...
Frameworks
Angular
Stable : v12, v13 en cours
Strict type by default
Proposal pour des modules optionnels
Frameworks
Vue.js
Version : 3.2
Composition API (meilleure séparation du code)
L'écosystème migre vers la v3
Frameworks
Approche légère : Svelte
A mi-chemin entre framework et compilateur :
analyse poussée au build pour maximiser le code au runtime dans le navigateur
Outils
Outils
data:image/s3,"s3://crabby-images/d9a38/d9a384ed300ef1edf1f6cdbc2d10b1a644d19d00" alt=""
Outils
Lighthouse - Core Web Vitals (LCP - Largest Contentful Paint, FID - First Input Delay, CLS - Cumulative Layout Shift)
webpack / rollup / parcel
vite / snowpack
CLI de vos frameworks favoris
Outils
Outils
Node.js 16
- Apple M1 support
- npm v7
Outils
data:image/s3,"s3://crabby-images/51a32/51a32cf755fdadf69341eb40927a001c22a23c72" alt=""
APIs
APIs
APIs
😀 - iOS 14.3 adds support for MediaRecorder API
😀 - iOS 15 adds support for Web Share API
😀 - iOS 15 adds support for WebGL 2.0
😐 - Apple declined to implement 16 Web APIs in Safari due to privacy concerns
The Stackless Way
data:image/s3,"s3://crabby-images/d0526/d05263a82006fd89183327de6860fc1c9ac674c0" alt=""
Merci pour votre attention !
Des questions ?
Slides : bit.ly/3otoogi
data:image/s3,"s3://crabby-images/0418d/0418d5e09e70603d9ab9344c44339fae54d84ea4" alt=""
Crédit photos - Unsplash.com
Écosystème web en 2021 : welcome to the jungle
By Vincent Ogloblinsky
Écosystème web en 2021 : welcome to the jungle
- 1,509