Maison interface Web Tutoriel H5 Comment utiliser postMessage pour transférer des données entre deux pages Web dans H5

Comment utiliser postMessage pour transférer des données entre deux pages Web dans H5

Jan 09, 2018 am 09:28 AM
html5 postmessage

Cette fois, je vais vous montrer comment utiliser postMessage dans H5 pour transférer des données entre deux pages Web. Comment utiliser postMessage dans H5 pour transférer des données entre deux pages Web ? PostMessage Quelles sont les précautions pour transférer des données entre deux pages web Voici un cas pratique, jetons un oeil.

On estime que peu de gens savent qu'il existe une API window.postMessage dans l'API HTML5. La fonction de window.postMessage est de permettre aux programmeurs d'envoyer des informations de données entre deux fenêtres/frames à travers des domaines. Fondamentalement, c'est comme AJAX inter-domaines, mais au lieu d'interagir entre le navigateur et le serveur, il communique entre deux clients. Jetons un coup d'œil au fonctionnement de window.postMessage. Tous les navigateurs, à l'exception d'IE6 et IE7, prennent en charge cette fonctionnalité.

Fin de l'envoi des données

La première chose que nous devons faire est de créer l'initiateur de la communication, qui est la source de données "source". En tant qu'initiateur, nous pouvons ouvrir une nouvelle fenêtre ou créer une iframe et envoyer des données à la nouvelle fenêtre pour plus de simplicité, nous l'envoyons toutes les 6 secondes, puis créons un écouteur de message pour écouter les informations de retour de la fenêtre cible. .

//弹出一个新窗口   
var domain = 'http://scriptandstyle.com';   
var myPopup = window.open(domain    
            + '/windowPostMessageListener.html','myWindow');   
  
//周期性的发送消息   
setInterval(function(){   
 var message = 'Hello!  The time is: ' + (new Date().getTime());   
 console.log('blog.local:  sending message:  ' + message);   
        //send the message and target URI   
 myPopup.postMessage(message,domain);   
},6000);   
  
//监听消息反馈   
window.addEventListener('message',function(event) {   
 if(event.origin !== 'http://scriptandstyle.com') return;   
 console.log('received response:  ',event.data);   
},false);
Copier après la connexion

Ici, j'ai utilisé window.addEventListener, mais cela ne fonctionne pas dans IE car IE utilise window.attachEvent. Si vous ne souhaitez pas déterminer le type de navigateur, vous pouvez utiliser certaines bibliothèques d'outils, telles que jQuery ou Dojo.

En supposant que votre fenêtre s'ouvre normalement, nous envoyons un message - vous devez spécifier l'URI (si nécessaire, vous devez spécifier le protocole, l'hôte, le numéro de port, etc.), et le destinataire du message doit être à cet URI spécifié. Si la fenêtre cible est remplacée, le message ne sera pas envoyé.

Nous avons également créé un écouteur d'événement pour recevoir des informations de retour. Une chose est extrêmement importante, vous devez vérifier l'URI de la source du message ! Vous ne pouvez traiter les messages de la partie cible que s'ils sont légitimes.

Si vous utilisez une iframe, le code doit être écrit comme ceci :

//捕获iframe   
var domain = 'http://scriptandstyle.com';   
var iframe = document.getElementById('myIFrame').contentWindow;   
  
//发送消息   
setInterval(function(){   
 var message = 'Hello!  The time is: ' + (new Date().getTime());   
 console.log('blog.local:  sending message:  ' + message);   
        //send the message and target URI   
 iframe.postMessage(message,domain);    
},6000);
Copier après la connexion

Assurez-vous que vous utilisez la propriété contentWindow de l'iframe, pas l'objet nœud.

Fin de réception des données

Ce que nous souhaitons développer ensuite, c'est la page de fin de réception des données. Il y a un écouteur d'événement dans la fenêtre du récepteur qui écoute l'événement « message ». De même, vous devez également vérifier l'adresse de la source du message. Les messages peuvent provenir de n'importe quelle adresse. Assurez-vous que le message en cours de traitement provient d'une adresse fiable.

//响应事件   
window.addEventListener('message',function(event) {   
 if(event.origin !== 'http://davidwalsh.name') return;   
 console.log('message received:  ' + event.data,event);   
 event.source.postMessage('holla back youngin!',event.origin);   
},false);
Copier après la connexion

L'extrait de code ci-dessus sert à renvoyer des informations à la source du message pour confirmer que le message a été reçu. Voici plusieurs attributs d'événement importants :

source – source du message, fenêtre d'envoi du message/iframe.
origine – URI de la source du message (peut inclure le protocole, le nom de domaine et le port), utilisé pour vérifier la source de données.
données – les données envoyées par l'expéditeur au destinataire.

Ces trois attributs sont des données qui doivent être utilisées dans la transmission des messages.

Utiliser window.postMessage

Comme beaucoup d'autres technologies web, si vous ne vérifiez pas la validité de la source de données, l'utilisation de cette technologie deviendra très dangereuse. La sécurité de votre application vous impose d'être responsable ; pour ça. window.postMessage est comme PHP par rapport à la technologie JavaScript. window.postMessage c'est cool, n'est-ce pas ?


Je pense que vous maîtrisez les méthodes après avoir lu ces cas. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture connexe :

Étapes détaillées pour créer une plateforme de gestion de livres à l'aide de vue.js

Comment compter la somme d'un tableau dans bootstrap Le nombre de

Comment utiliser JS pour désactiver et activer les boutons

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Bordure de tableau en HTML Bordure de tableau en HTML Sep 04, 2024 pm 04:49 PM

Guide de la bordure de tableau en HTML. Nous discutons ici de plusieurs façons de définir une bordure de tableau avec des exemples de bordure de tableau en HTML.

Tableau imbriqué en HTML Tableau imbriqué en HTML Sep 04, 2024 pm 04:49 PM

Ceci est un guide des tableaux imbriqués en HTML. Nous discutons ici de la façon de créer un tableau dans le tableau ainsi que des exemples respectifs.

Marge gauche HTML Marge gauche HTML Sep 04, 2024 pm 04:48 PM

Guide de la marge HTML gauche. Nous discutons ici d'un bref aperçu de la marge gauche HTML et de ses exemples ainsi que de son implémentation de code.

Disposition du tableau HTML Disposition du tableau HTML Sep 04, 2024 pm 04:54 PM

Guide de mise en page des tableaux HTML. Nous discutons ici des valeurs de la mise en page des tableaux HTML ainsi que des exemples et des résultats en détail.

Liste ordonnée HTML Liste ordonnée HTML Sep 04, 2024 pm 04:43 PM

Guide de la liste ordonnée HTML. Ici, nous discutons également de l'introduction de la liste et des types HTML ordonnés ainsi que de leur exemple respectivement.

Espace réservé d'entrée HTML Espace réservé d'entrée HTML Sep 04, 2024 pm 04:54 PM

Guide de l'espace réservé de saisie HTML. Nous discutons ici des exemples d'espace réservé d'entrée HTML ainsi que des codes et des sorties.

Déplacer du texte en HTML Déplacer du texte en HTML Sep 04, 2024 pm 04:45 PM

Guide pour déplacer du texte en HTML. Nous discutons ici d'une introduction, du fonctionnement des balises de sélection avec la syntaxe et des exemples à implémenter.

Bouton HTML onclick Bouton HTML onclick Sep 04, 2024 pm 04:49 PM

Guide du bouton HTML onclick. Nous discutons ici de leur introduction, de leur fonctionnement, des exemples et de l'événement onclick dans divers événements respectivement.

See all articles