Cet article fait partie de mes compte-rendus écrits à la suite de ng-europe ayant eu lieu à Paris du 24 au 26 octobre 2016
RxJS s’est retrouvé dans plusieurs conférences. Comme pour le backend la programmation reactive est très présente dans les conférences JavaScript
Rob Wormald : Angular & RxJS Slides
javascripter. googler. developer advocate for angular.
RxJS s’est retrouvé dans plusieurs conférences. Comme pour le backend la programmation reactive est très présente dans les conférences JavaScript
Rob Wormald : Angular & RxJS Slides
javascripter. googler. developer advocate for angular.
photo de Philippe Chatel
Les librairies Rx (reactive extensions) permettent de faire de la programmation asynchrone basée sur des événements. Les données peuvent être assez diverses. On peut retrouver un flux de données transmises par un fichier, un appel REST, une série d’événement utilisateurs, des notifications du système.
Avec Rx ces données apparaissent comme des données observables. Votre application peut ensuite s’abonner à ces séquences observables afin de pouvoir exécuter un traitement quand de nouvelles informations arrivent (en asynchrone donc).
RxJS est une implémentation en JS (sans dépendance) qui peut à la fois interagir avec des flux de données synchrones (objets Iterable) ou des données asynchrones (objets Promise). Vous pouvez utiliser l’extension rx.angular pour bénéficier de ces possibilités dans Angular 1.
Voici un exemple Angular utilisant les observables pour récupérer des données
export class AppComponent { myControl = new FormControl(); constructor(http:Http){ this.myControl.valueChanges .map(text => `http://api.com?q=${text}`) .flatMap(url => http.get(url), (req, res) => res.json()) .subscribe(results => console.log(results)); } }
Je vous conseille de regarder le talk de Rob quand il sera en ligne
Voir la vidéo
André Staltz You will learn RxJS
Reactive programming expert, @cyclejs creator and @reactivex addict.
Alors cette conférence était pour moi une des meilleures. Live coding oblige… André est arrivé pour nous parler de RxJS et des Observables que l’on retrouve aussi maintenant dans Angular. Son but était de repartir de 0 pour montrer les concepts de base qui sont parfois mal appréhendés.
photo de Philippe Chatel
Aujourd’hui quand vous manipulez une collection en mode synchrone vous utilisez un callback (ici j’affiche les éléments du tableau [1, 2, 3])
[1, 2, 3].forEach(elt => console.log(elt));
Quand vous faites un appel distant asynchrone vous utilisez 2 callbacks
fetch('api/sponsors').then( response => console.log(response.json()), error => console.log(error) );
D’autres fonctions peuvent avoir 3 callbacks. Mais en gros nous sommes toujours sur le même schéma
- un callback pour savoir quoi faire après (next)
- un callback à exécuter en ca d’erreur (error)
- un callback à exécuter quand tout est terminé (complete)
Un stream peut être vu comme l’objet qui va être scruté de près quand il changera (objet Observable). Les observables peuvent être surveillés par un ou plusieurs observateurs (Observer que nous avons vu avant et qui prend trois méthodes next, error et complete).
Un Observable peut se créer de cette manière
myEventStream = new Observable(observer => { setTimeout(() => { observer.next(42); }, 1000); setTimeout(() => { observer.next(43); }, 2000); setTimeout(() => { observer.complete(); }, 3000); });
En gros je vais recevoir de manière asynchrone des données toutes les secondes. Le stream sera terminé au bout de 3. Cet observable va ensuite être lié à un Observer via la méthode suscribe. Un Observer implémentera en gros les 3 callbacks de tout à l'heure
let values = []; let subscription = myEventStream.subscribe( val => values.push(val), error => console.error(error), () => console.log('done') );
André nous a ensuite expliqué comment rajouté des opérateurs sur les Observable (map, filter...). En attendant de regarder la vidéo je vous conseille un de ces articles qui est très bien pour expliquer le fonctionnement de Rx.
Tero Parviainen Reactive Music Apps in Angular and RxJS
Independent contractor, programmer, writer.
Certainement la conférence arrivant en tête à l’applaudimètre. C’était très bien mais mieux qu’un résumé écrit par mes soins voici un article de Tero qui explique ce qu’il a montré
Cette conférence montre ce que l’on peut faire en utilisant Angular 2 RxJS quand on a du talent.
Aucun commentaire:
Enregistrer un commentaire
Remarque : Seul un membre de ce blog est autorisé à enregistrer un commentaire.