Movatterモバイル変換


[0]ホーム

URL:


MDN Web Docs

Cette page a été traduite à partir de l'anglais par la communauté. Vous pouvez également contribuer en rejoignant la communauté francophone sur MDN Web Docs.

Broadcast Channel API

BaselineWidely available

L'APIBroadcast Channel permet la communication entre descontextes de navigation (c'est-à-dire desfenêtres,onglets,cadres, ouiframes) etworkers d'une mêmeorigine.

Note : Cette fonctionnalité est disponible via lesWeb Workers.

En créant un objetBroadcastChannel, vous pouvez y recevoir n'importe quel message qui lui a été envoyé. Vous n'avez pas à maintenir de référence aux cadres ouworkers avec lesquels vous souhaitez communiquer, car ils « s'abonnent » à un canal dédié en construisant leur propre objetBroadcastChannel avec le même nom, et obtiennent un canal de communication bi-directionnel avec chacun d'eux.

Les principes de l'API Broadcast Channel

L'interfaceBroadcast Channel

Créer ou rejoindre un canal

Un client rejoint un canal de diffusion en créant un objetBroadcastChannel. Sonconstructeur prend un unique paramètre : lenom du canal. S'il est le premier à se connecter à ce nom de canal de diffusion, alors le canal sous-jacent est créé.

js
// Connexion au canal de diffusionconst bc = new BroadcastChannel("canal_test");

Envoi d'un message

Il suffit d'appeler la méthodepostMessage() sur l'objetBroadcastChannel créé, qui prend n'importe quel objet comme argument. Un exemple de message :

js
// Exemple d'envoi d'un message très simplebc.postMessage("Ceci est un message test.");

Les données envoyées sur le canal sont sérialisées via l'algorithme de clonage de structure. Ceci implique que vous pouvez envoyer un large spectre de type de données de manière sure sans avoir à les sérialiser par vous-même.

Cette API n'associe aucune sémantique particulière aux messages, c'est donc au code de savoir à quelle sorte de message s'attendre et quel usage il peut en tirer.

Réception d'un message

Lorsqu'un message est posté, un évènementmessage est distribué sur chaque objetBroadcastChannel connecté à ce canal. Une fonction peut être exécutée pour le traitement de cet évènement en utilisant le gestionnaire d'évènementsonmessage :

js
// Un gestionnaire affichant simplement les messages sur la console :bc.onmessage = (event) => {  console.log(event);};

Déconnexion d'un canal

Pour quitter un canal, appelez la méthodeclose() de l'objet. Cet appel déconnectera l'objet du canal sous-jacent permettant au ramasse-miettes de s'exécuter.

js
// Déconnexion du canalbc.close();

Conclusion

L'interface intégrée de l'APIBroadcast Channel permet une communication inter-contexte. Il peut être utilisé pour détecter des actions utilisateurs dans d'autre onglets d'une même origine, telle qu'une connexion ou déconnexion d'utilisateur du site.

Le protocole ne définit pas le contenu des messages ni leurs significations. Il sera à la charge de la développeuse ou du développeur d'implanter leur propre jeu de messages et traitements associés.

Spécifications

Specification
HTML
# broadcasting-to-other-browsing-contexts

Compatibilité des navigateurs

Voir aussi

BroadcastChannel, l'interface qui porte cette API.

Help improve MDN

Learn how to contribute.

This page was last modified on byMDN contributors.


[8]ページ先頭

©2009-2025 Movatter.jp