HTML5 - Messagerie Web

La messagerie Web est la capacité d'envoyer des messages en temps réel du serveur au navigateur client. Il remplace le problème de communication interdomaine dans différents domaines, protocoles ou ports

Par exemple, vous souhaitez envoyer les données de votre page au conteneur publicitaire qui est placé dans iframe ou voice-versa, dans ce scénario, le navigateur lève une exception de sécurité. Avec la messagerie Web, nous pouvons transmettre les données sous forme d'événement de message.

Événement de message

Les événements de message déclenchent la messagerie entre documents, la messagerie de canal, les événements envoyés par le serveur et Web sockets.it a décrit par l'interface d'événement de message.

Les attributs

N ° Sr. Attributs et description
1

data

Contient des données de chaîne

2

origin

Contient le nom de domaine et le port

3

lastEventId

Contient un identifiant unique pour l'événement de message actuel.

4

source

Contient à Une référence à la fenêtre du document d'origine

5

ports

Contient les données envoyées par n'importe quel port de message

Envoi d'un message croisé

Avant d'envoyer un message croisé de documents, nous devons créer un nouveau contexte de navigation Web en créant un nouvel iframe ou une nouvelle fenêtre. Nous pouvons envoyer les données en utilisant avec postMessage () et il a deux arguments. Ils sont comme -

  • message - Le message à envoyer
  • targetOrigin - Nom d'origine

Exemples

Envoi d'un message d'iframe au bouton

var iframe = document.querySelector('iframe');
var button = document.querySelector('button');

var clickHandler = function() {
   iframe.contentWindow.postMessage('The message to send.',
      'https://www.tutorialspoint.com);
}
button.addEventListener('click',clickHandler,false);

Réception d'un message croisé dans le document de réception

var messageEventHandler = function(event){
   
   // check that the origin is one we want.
   if(event.origin == 'https://www.tutorialspoint.com') {
      alert(event.data);
   }
}
window.addEventListener('message', messageEventHandler,false);

Messagerie de chaîne

La communication bidirectionnelle entre les contextes de navigation est appelée messagerie de canal. Il est utile pour la communication entre plusieurs origines.

Les objets MessageChannel et MessagePort

Lors de la création de messageChannel, il crée en interne deux ports pour envoyer les données et les transférer vers un autre contexte de navigation.

  • postMessage() - Publier le canal de lancement de message

  • start() - Il envoie les données

  • close() - Il ferme les ports

Dans ce scénario, nous envoyons les données d'une iframe à une autre iframe. Ici, nous invoquons les données en fonction et passons les données au DOM.

var loadHandler = function() {
   var mc, portMessageHandler;
   mc = new MessageChannel();
   window.parent.postMessage('documentAHasLoaded','http://foo.example',[mc.port2]);
   
   portMessageHandler = function(portMsgEvent) {
      alert( portMsgEvent.data );
   }
   
   mc.port1.addEventListener('message', portMessageHandler, false);
   mc.port1.start();
}
window.addEventListener('DOMContentLoaded', loadHandler, false);

Au-dessus du code, il prend les données du port 2, maintenant il passera les données à la deuxième iframe

var loadHandler = function() {
   var iframes, messageHandler;
   iframes = window.frames;
   
   messageHandler = function(messageEvent) {
      
      if( messageEvent.ports.length > 0 ) {
         
         // transfer the port to iframe[1]
         iframes[1].postMessage('portopen','http://foo.example',messageEvent.ports);
      }
   }
   window.addEventListener('message',messageHandler,false);
}
window.addEventListener('DOMContentLoaded',loadHandler,false);

Maintenant, le deuxième document gère les données à l'aide de la fonction portMsgHandler.

var loadHandler() {
   
   // Define our message handler function
   var messageHandler = function(messageEvent) {
   
      // Our form submission handler
      
      var formHandler = function() {
         var msg = 'add <[email protected]> to game circle.';
         messageEvent.ports[0].postMessage(msg);
      }
      document.forms[0].addEventListener('submit',formHandler,false);
   }
   window.addEventListener('message',messageHandler,false);
}
window.addEventListener('DOMContentLoaded',loadHandler,false);