La spécification des composants web (Web Components en anglais) est en cours de normalisation par le World Wide Web Consortium (W3C), l'organisme de normalisation du web.

Logo du World Wide Web Consortium
Logo du World Wide Web Consortium

Les composants web permettent aux développeurs de créer des balises HTML personnalisées et réutilisables.

"Les composants web permettent de combiner plusieurs éléments pour créer des composants d'interface graphique (widgets) réutilisables avec un niveau de richesse et d'interactivité sans commune mesure avec ce qui est aujourd'hui possible en se limitant aux CSS", explique le W3C.

Les composants web s'appuient sur plusieurs interfaces de programmation (API) du W3C :

  • templates : squelettes pour des éléments HTML instanciables
  • shadow DOM : ce qui sera public ou privé dans les éléments
  • custom elements : pour créer et enregistrer de nouveaux éléments HTML et les faire reconnaître par le navigateur
  • HTML imports : pour packager ses composants (CSS, JavaScript…)
  • model driven views : fournit un databinding semblable à celui d'AngularJS
  • Web animations : des APIs pour mettre en œuvre des animations complexes
  • pointer events : unifie les événements souris, tactile et stylet

Polyfills

modifier

Plusieurs polyfills commencent à apparaître pour les composants web :

  • webcomponents.js
  • Polymer de Google, présenté lors d'un salon Google I/O, et basé sur webcomponents.js
  • x-Tag, de la fondation Mozilla
  • Bosonic

Hello World

modifier

Voici un exemple d'application assez minimaliste (Hello World) utilisant un composant web (via le polyfill webcomponents.js) :

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Hello world</title>

    <!-- Importing Web Component's Polyfill -->
    <script src="bower_components/webcomponentsjs/webcomponents.min.js"></script>

    <!-- Importing Custom Elements -->
    <link rel="import" href="src/hello-world.html">
</head>
<body>

    <!-- Using Custom Elements -->
    <hello-world who="World"></hello-world>

</body>
</html>

Voir aussi

modifier

Liens externes

modifier