Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie verwendet man postMessage in Javascript?

藏色散人
Freigeben: 2021-09-12 16:44:06
nach vorne
3409 Leute haben es durchsucht

Die übergeordnete Seite und die untergeordnete Seite befinden sich in unterschiedlichen Domänen, und postMessage wird im Dialog zwischen ihnen verwendet. Im Folgenden werden sie der Einfachheit halber gemeinsam als Seiten F und C bezeichnet.

Das Klickereignis der Schaltfläche auf Seite C sendet eine kleine Nachricht C an Seite F. Seite F empfängt die kleine Nachricht C und führt die Logik-LC aus. Nachdem die LC-Ausführung abgeschlossen ist, sendet Seite F eine kleine Nachricht F an Seite C. Seite C empfängt die Nachricht klein F. Logisches LF ausführen. Kurz gesagt bedeutet dies, dass die Seiten F und C miteinander kommunizieren.

kann als

ähnlich der Eltern-Kind-Komponentenkommunikation in React betrachtet werden.

C-Seiten-JS-Code:

var btnObj = document.getElementById('buttons');
btnObj.onclick = function(){
     var defaultAdData = {
                 type:'advert', 
                 gameData:{
                     adId: '123'
                 }
         };
     window.parent.postMessage(JSON.stringify(defaultAdData), '*');
    /*我是错误代码:
     var receiveMessage = function(event) {
         var datas = JSON.parse(event.data);
         if (datas.type === "adGivePrize"&&datas.givePrize) {
             alert(‘click’);
         }
     }
     window.addEventListener("message", receiveMessage, false);*/
 }
 /*我是正确代码:
 var receiveMessage = function(event) {
     var datas = JSON.parse(event.data);
     if (datas.type === "adGivePrize"&&datas.givePrize) {
         alert(‘click’);
     }
 }
 window.addEventListener("message", receiveMessage, false);*/
Nach dem Login kopieren

F-Seiten-JS-Code:

var receiveMessage = function(event) {
      var datas = JSON.parse(event.data);
      if (datas.type === "advert") {
            var postIframeData = {
                    type:'adGivePrize',
                    givePrize:true
            };
            //iframe发送信息~~~~
            window.frames[0].postMessage(JSON.stringify(postIframeData), '*');
      }
}

window.addEventListener("message", receiveMessage, false);
Nach dem Login kopieren

Kurz gesagt, diese Methode ermöglicht die Kommunikation zwischen zwei unabhängigen Seiten, sodass externe Projekte oder eingebettete Iframes miteinander kommunizieren können.

Empfohlenes Lernen: „Javascript-Grundlagen-Tutorial

Das obige ist der detaillierte Inhalt vonWie verwendet man postMessage in Javascript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage