HTML5 - wiadomości internetowe

Wiadomości internetowe to możliwość wysyłania wiadomości w czasie rzeczywistym z serwera do przeglądarki klienta. Zastępuje problem komunikacji między domenami w różnych domenach, protokołach lub portach

Na przykład, jeśli chcesz wysłać dane ze strony do kontenera reklam, który jest umieszczony w ramce iframe lub na odwrót, w tym scenariuszu przeglądarka zgłasza wyjątek bezpieczeństwa. Dzięki wiadomościom internetowym możemy przekazywać dane jako zdarzenie wiadomości.

Wiadomość Wydarzenie

Zdarzenia wiadomości odpalają Przesyłanie wiadomości między dokumentami, przesyłanie wiadomości w kanałach, zdarzenia wysyłane przez serwer i gniazda sieciowe. Zostało opisane przez interfejs zdarzenia wiadomości.

Atrybuty

Sr.No. Atrybuty i opis
1

data

Zawiera dane ciągów

2

origin

Zawiera nazwę domeny i port

3

lastEventId

Zawiera unikalny identyfikator aktualnego zdarzenia wiadomości.

4

source

Zawiera odniesienie do okna dokumentu źródłowego

5

ports

Zawiera dane, które są wysyłane przez dowolny port wiadomości

Wysyłanie wiadomości obejmującej różne dokumenty

Przed wysłaniem wiadomości między dokumentami musimy utworzyć nowy kontekst przeglądania sieci WWW, tworząc nową ramkę iframe lub nowe okno. Możemy wysłać dane za pomocą funkcji postMessage () i ma ona dwa argumenty. Są jak -

  • message - wiadomość do wysłania
  • targetOrigin - Nazwa pochodzenia

Przykłady

Wysyłanie wiadomości z iframe do przycisku

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);

Odbieranie wiadomości obejmującej wiele dokumentów w dokumencie odbierającym

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);

Wiadomości na kanale

Dwukierunkowa komunikacja między kontekstami przeglądania nazywa się przesyłaniem komunikatów kanałowych. Jest to przydatne do komunikacji z wieloma źródłami.

Obiekty MessageChannel i MessagePort

Tworząc messageChannel, wewnętrznie tworzy dwa porty do wysyłania danych i przekazywania ich do innego kontekstu przeglądania.

  • postMessage() - Opublikuj kanał przesyłania wiadomości

  • start() - Wysyła dane

  • close() - Zamyka porty

W tym scenariuszu wysyłamy dane z jednego elementu iframe do innego iframe. Tutaj wywołujemy dane w funkcji i przekazujemy dane do 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);

Powyższy kod pobiera dane z portu 2, teraz przekazuje dane do drugiego elementu 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);

Teraz drugi dokument obsługuje dane za pomocą funkcji 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);