ホームページ ウェブフロントエンド H5 チュートリアル HTML5 ウィンドウ/iframe クロスドメイン メッセージング API の概要_html5 チュートリアルのスキル

HTML5 ウィンドウ/iframe クロスドメイン メッセージング API の概要_html5 チュートリアルのスキル

May 16, 2016 pm 03:48 PM
html5 iframe

元のアドレス: HTML5 の window.postMessage API
オンライン例: HTML5 の window.postMessage の使用(ログを表示するにはコンソールを開いてください)

I window.postMessage をカプセル化する MooTools プラグイン「PostMessager」を作成しました。ここをクリックしてダウンロードできます。

HTML5 の window.postMessage インターフェイス API を理解している人は多くありません。 window.postMessage を使用すると、複数のウィンドウ/フレーム間でデータと情報をクロスドメイン転送できます。本質的に、window.postMessage はクロスドメイン Ajax リクエストの役割を果たします。もちろん、連携するリモート サーバーは必要ありません。次に、window.postMessage の仕組みと、FireFox、IE8、Opera、Safari、Chrome での使用方法を紹介します。

1. メッセージ送信終了
最初のステップは「ニュースソース」を設定することです。このメッセージ ソースを通じて、ウィンドウ レベルのデータ (メッセージ) を新しく開かれたウィンドウ (または iframe) に送信できます。次の例では、新しいウィンドウにメッセージを送信する頻度は 6 秒に 1 回で、ターゲット ウィンドウから返された応答情報を処理するようにイベント リスニングが設定されています。

コードをコピーします
コードは次のとおりです。

関数トレース(メッセージ){
var infos = Array.prototype.slice.call(arguments,0).join(" ");
if("console" in window){
console.log(infos); } else {
alert(infos);
}
}// ポップアップウィンドウを作成します
var domain = 'http://scriptandstyle.com'; var myPopup = window.open (domain '/windowPostMessageListener.html','myWindow');
//定期的にメッセージを送信します
setInterval(function(){
var message = '今の時間: ' (new Date().getTime( ));
trace('送信されたメッセージ: ' message);
myPopup.postMessage(message,domain); //データ情報を送信し、ターゲット URI を設定します。 },6*1000 );
function bindingEvent(target,noOnEventName,handler){
if(window.addEventListener){
target.addEventListener(noOnEventName,handler); else if(window) .attachEvent){
// IE のリスニング設定関数はattachEvent
target.attachEvent("on" noOnEventName,handler)
} else {
target["on" noOnEventName]=handler ;
}
};
// 受信した情報を監視します。
bindEvent(window,'message',function(event)) {
// 特定のドメインからのメッセージのみを受信します
if(event.origin !== 'http://scriptandstyle.com') return;
trace('受信した応答情報: ',event.data);


元の記事の著者は、イベントをバインドするために window.addEventListener メソッドを使用していますが、IE ではエラーが報告されます (IE は window.attachEvent です)。もちろん、イベントをラップする関数を作成することもできます。または、MooTools や jQuery/dojo などの既製のクラス ライブラリを使用して実現します。
上記の例では、新しいウィンドウが正常に開いた場合、ウィンドウ オブジェクト参照 myPopup を通じてメッセージを送信し、一致する必要がある URI (プロトコル、ホスト名、ポート番号) を指定できます (ユーザーが子ウィンドウにジャンプした場合)。
同様に、メッセージを受信するイベント ハンドラー関数もバインドしました。複数のフレームを操作するときに混乱しないように、すべての URI によって送信されたメッセージを受信できるため、メッセージ イベントのorigin 属性を確認することが重要であることに注意してください。 発信元を確認した後、このメッセージを処理する方法は、特定のビジネスとニーズによって異なります。

iframe を使用する場合、コードは次のとおりです。





コードをコピーします

コードは次のとおりです。次のように:
// 別のウィンドウも作成します (iframe、frame、frameset、top、window はすべてウィンドウ関連のオブジェクトです)。 var domain = 'http://scriptandstyle.com '; var iframe = document.getElementById('myIFrame').contentWindow;
// もちろん、イベント駆動型メソッドも使用できます。 。 。
setInterval(function(){
var message = '現在時刻: ' (new Date().getTime());
trace('データ ソース.メッセージ送信: ' message);
iframe.postMessage(message,domain); //データ情報を送信し、ターゲット URI を設定します
},6*1000);


iframe オブジェクトの contentWindow 属性にアクセスできることを確認します—— iframe オブジェクトだけではありません。


2. メッセージ受信終了
プロセス全体の 2 番目のステップは、ターゲット ウィンドウを準備することです。宛先ウィンドウが行う必要があるのは、メッセージ イベントをリッスンすることだけであり、もちろんイベントの発信元メッセージ ソースを確認することだけです。もう一度注意してください: メッセージ イベント ハンドラーは、任意のドメイン名から送信されたメッセージを受け入れることができるため、送信元を確認し、信頼リストからのメッセージのみを処理することが非常に重要です。



コードをコピー

コードは次のとおりです:

// 受信した情報を監視します。
bindEvent(window,'message',function(event) {
// 特定のドメインからのメッセージのみを受信します
if(event.origin !== 'http://davidwalsh.name') return;
trace('リッスンした情報: ',event.data);
//応答メッセージ
イベント.source .postMessage(""こんにちは、メッセージを受け取りました。event.origin);

上記の例は、リクエスト スクエアに応答メッセージを返信します。 。
message イベントの重要な属性は次のとおりです。
source - メッセージを送信するウィンドウ/iframe オブジェクト
origin - メッセージを送信するウィンドウに対応する URI (プロトコル、ドメイン、およびポートの場合)
data - 特定のデータ情報
これら 3 つのオブジェクトは、メッセージング システムと検証に不可欠です。


window.postMessage の使用に関する注意事項 他のすべての Web テクノロジーと同様に、(イベント ソースを確認せずに) 不適切に使用すると、その危険性が明らかです。もちろん、セキュリティはあなた次第です。
window.postMessage は JavaScript テクノロジの PHP に非常に似ています (笑、広告はほとんどありません!)。window.postMessage は非常に優れたテクノロジだと思いますが、どう思いますか?
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HTML のネストされたテーブル HTML のネストされたテーブル Sep 04, 2024 pm 04:49 PM

これは、HTML でのネストされたテーブルのガイドです。ここでは、テーブル内にテーブルを作成する方法をそれぞれの例とともに説明します。

HTMLの表の境界線 HTMLの表の境界線 Sep 04, 2024 pm 04:49 PM

HTML の表の境界線に関するガイド。ここでは、HTML でのテーブルの境界線の例を示しながら、テーブル境界線を定義する複数の方法について説明します。

HTML 左マージン HTML 左マージン Sep 04, 2024 pm 04:48 PM

HTML マージン左のガイド。ここでは、HTML margin-left の概要とその例、およびそのコード実装について説明します。

HTML テーブルのレイアウト HTML テーブルのレイアウト Sep 04, 2024 pm 04:54 PM

HTML テーブル レイアウトのガイド。ここでは、HTML テーブル レイアウトの値と例および出力について詳しく説明します。

HTML 順序付きリスト HTML 順序付きリスト Sep 04, 2024 pm 04:43 PM

HTML 順序付きリストのガイド。ここでは、HTML 順序付きリストと型の導入とその例についても説明します。

HTML 内のテキストの移動 HTML 内のテキストの移動 Sep 04, 2024 pm 04:45 PM

HTML でのテキストの移動に関するガイド。ここでは、概要、マーキー タグが構文でどのように機能するか、および実装例について説明します。

HTML入力プレースホルダー HTML入力プレースホルダー Sep 04, 2024 pm 04:54 PM

HTML 入力プレースホルダーのガイド。ここでは、コードと出力とともに HTML 入力プレースホルダーの例について説明します。

HTML の onclick ボタン HTML の onclick ボタン Sep 04, 2024 pm 04:49 PM

HTML オンクリック ボタンのガイド。ここでは、それらの紹介、動作、例、およびさまざまなイベントでの onclick イベントについてそれぞれ説明します。

See all articles