ホームページ > ウェブフロントエンド > H5 チュートリアル > クロスドメイン通信の問題を解決するhtml5 postMessageの詳細解説

クロスドメイン通信の問題を解決するhtml5 postMessageの詳細解説

青灯夜游
リリース: 2018-10-09 16:10:11
転載
2070 人が閲覧しました

この記事では、HTML5 postMessage がクロスドメイン通信の問題をどのように解決するかを詳しく説明した関連情報を中心に紹介します。必要な方は参考にしていただければ幸いです。

この記事では、クロスドメイン通信の問題を解決するための html5 postMessage の詳細な説明を紹介し、その内容を皆さんと共有します。

レンダリング:

ポストメッセージ解析 HTML5 は、安全なクロスソース通信を実現するための新しいメカニズム PostMessage を提供します。

構文:

otherWindow.postMessage(message, targetOrigin, [transfer]);
ログイン後にコピー

otherWindow: 他のウィンドウへの参照。 IFRAME の contentWindow プロパティを実行すると、window.open がウィンドウ オブジェクトを返します。

メッセージ: 他のウィンドウに送信されるデータ。

targetOrigin: ウィンドウのorigin属性を使用して、どのウィンドウがメッセージ・イベントを受信できるかを指定します。その値は文字「*」(無制限を示す)またはTransferableの文字列です。オブジェクトと同時に配信されます。これらのオブジェクトの所有権はメッセージの受信者に譲渡され、送信者は所有権を保持しなくなります。

element.addEventListener(event,fn,useCaption); click MouseEnter MouseLeave コールバック関数 useCaption などの 3 つのパラメータ イベント イベントを使用して、バブルするかキャプチャするかを記述します。デフォルト値は false で、バブル配信を意味します。値が true の場合、その値はキャプチャされて渡されます。実装方法

メインインターフェースmain.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>跨域数据访问</title>
  <script type="text/javascript">
         window.addEventListener(&#39;message&#39;,function(e){
           console.log("e--->",e);
           const data = e.data;
           document.getElementById(&#39;main1&#39;).style.backgroundColor=e.data;
         },false)

  </script>
</head>
<body>
  <p id="main1" style="width:200px;height:200px;margin:100px;border:solid 1px #000;">
     我是主界面,等待接收iframe的传递
  </p>
  <p style="margin:100px;">
     iframe
     <iframe src="http://localhost:3000/iframe.html" width="800px" height="300px" ></iframe>
  </p>
</body>
</html>
ログイン後にコピー

iframeインターフェース

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
    <style type="text/css">
           html,body{
               height:100%;
               margin:0px;
           }
    </style>
</head>
  <body style="height:100%;">
        <p id="frame" style="height:200px; width:200px;background-color:rgb(204, 204, 0)" onclick="changeColor()">
           点击改变颜色
        </p>
        <script type="text/javascript">
             function changeColor(){
               var frame = document.getElementById(&#39;frame&#39;);
               var color=frame.style.backgroundColor;
               if(color==&#39;rgb(204, 102, 0)&#39;){
                   color=&#39;rgb(204, 204, 0)&#39;;
               }else{
                   color=&#39;rgb(204,102,0)&#39;;
               }
                console.log("frame===>",frame);
                console.log("color",color);
               frame.style.backgroundColor=color;
               window.parent.postMessage(color,&#39;*&#39;);
             }
        </script>
  </body>
</html>
ログイン後にコピー

要約: 以上がこの記事の全内容です。皆様の学習に少しでもお役に立てれば幸いです。 。関連チュートリアルの詳細については、Html5 ビデオ チュートリアルをご覧ください。

関連する推奨事項:

php 公共福祉トレーニング ビデオ チュートリアル

HTML5 グラフィック チュートリアル

HTML5オンライン マニュアル

以上がクロスドメイン通信の問題を解決するhtml5 postMessageの詳細解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:jb51.net
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート