postMessage의 경우 HTML5 기능이지만 IE8+를 지원합니다. 웹사이트에서 IE6 및 IE7을 지원할 필요가 없다면 window.postMessage를 사용할 수 있습니다. 도메인 간 또는 동일한 도메인 내에서 이전될 수 있습니다.
간단한 적용 시나리오를 제시한 것 뿐입니다. 물론 이 기능은 여러 곳에 사용될 수 있습니다.
페이지가 있고 해당 페이지에서 일부 사용자 정보를 얻은 경우 다른 페이지로 들어가려면 클릭하세요. 다른 페이지는 기본적으로 사용자 정보를 가져올 수 없습니다. window.postMessage를 통해 이 페이지에 사용자 정보를 전달할 수 있습니다. (물론 보안 및 기타 측면을 고려해야 합니다.)
코드 예
메시지 보내기:
JavaScript 코드는 내용을 클립보드에 복사합니다.
//弹出一个新窗口 var domain = 'https://haorooms.com'; var myPopup = window.open(domain + '/windowPostMessageListener.html','myWindow'); //周期性的发送消息 setTimeout(function(){ //var message = '当前时间是 ' + (new Date().getTime()); var message = {name:"站点",sex:"男"}; //你在这里也可以传递一些数据,obj等 console.log('传递的数据是 ' + message); myPopup.postMessage(message,domain); },1000);
지연하려면 일반적으로 보내기 전에 지연하기 위해 setTimeout 타이머를 사용합니다.
수락 페이지
JavaScript 코드는 내용을 클립보드에 복사합니다
//메시지 피드백 듣기
window.addEventListener('message',function(event) { if(event.origin !== 'https://haorooms.com') return; //这个判断一下是不是我这个域名跳转过来的 console.log('received response: ',event.data); },false);
아래와 같이 수락 페이지에서 데이터를 가져옵니다
iframe을 사용하는 경우 코드는 다음과 같아야 합니다. 다음과 같이 작성되었습니다:
JavaScript 코드 내용을 클립보드에 복사
//捕获iframe var domain = 'https://haorooms.com'; var iframe = document.getElementById('myIFrame').contentWindow; //发送消息 setTimeout(function(){ //var message = '当前时间是 ' + (new Date().getTime()); var message = {name:"站点",sex:"男"}; //你在这里也可以传递一些数据,obj等 console.log('传递的数据是: ' + message); //send the message and target URI iframe.postMessage(message,domain); },1000);
데이터 승인
내용을 클립보드에 복사하는 JavaScript 코드
//响应事件 window.addEventListener('message',function(event) { if(event.origin !== 'https://haorooms.com') return; console.log('message received: ' + event.data,event); event.source.postMessage('holla back youngin!',event.origin); },false);
위의 코드 조각은 메시지 소스에 정보를 피드백하고 메시지가 메시지가 수신되었습니다. 다음은 몇 가지 중요한 이벤트 속성입니다:
source – 메시지 소스, 메시지 전송 창/iframe.
origin – 데이터 소스를 확인하는 데 사용되는 메시지 소스의 URI(프로토콜, 도메인 이름 및 포트가 포함될 수 있음).
data – 발신자가 수신자에게 보내는 데이터입니다.
인스턴스 호출
메인 스레드에서 Worker 인스턴스를 생성하고 onmessage 이벤트를 수신합니다.
JavaScript 코드는 콘텐츠를 클립보드에 복사합니다.
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <title>Test Web worker</title> <script type="text/JavaScript"> function init(){ var worker = new Worker('compute.js'); //event 参数中有 data 属性,就是子线程中返回的结果数据 worker.onmessage= function (event) { // 把子线程返回的结果添加到 p 上 document.getElementById("result").innerHTML += event.data+"<br/>"; }; } </script> </head> <body onload="init()"> <p id="result"></p> </body> </html>
클라이언트의 Compute.js에서는 다음의 간단한 반복입니다. 여러 번 sum 연산을 수행하고 최종적으로 postMessage 메소드를 통해 결과가 메인 스레드로 반환되며, 일정 시간 동안 대기하는 것이 목적이다. 이 기간 동안 메인 스레드가 차단되어서는 안 됩니다. 사용자는 브라우저 드래그, 브라우저 창 확대 또는 축소 등을 통해 이 현상을 테스트할 수 있습니다. 이 비차단 메인 스레드의 결과는 웹 작업자가 달성하고자 하는 것입니다.
compute.js는 postMessage 메소드를 호출하여 계산 결과를 반환합니다.
JavaScript 코드는 내용을 클립보드에 복사합니다.
var i=0; function timedCount(){ for(var j=0,sum=0;j<100;j++){ for(var i=0;i<100000000;i++){ sum+=i; } } // 调用 postMessage 向主线程发送消息 postMessage(sum); } postMessage("Before computing,"+new Date()); timedCount(); postMessage("After computing,"+new Date());
이 사례를 읽으신 후 메소드를 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 주의하시기 바랍니다. PHP 중국어 웹사이트의 다른 관련 기사를 확인해보세요!
관련 읽기:
위 내용은 H5의 postMessage API에 대한 자세한 그래픽 및 텍스트 설명 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Theroottaginanhtmldocumentis.itservesasthetop-levellement thatenCapsulateslotherContent, 프로퍼 디코 언어 구조에있는 BrowserParsing을 보장합니다.

이 기사는 HTML 태그가 요소를 정의하는 데 사용되는 구문 마커이고 요소는 태그 및 내용을 포함한 완전한 단위라고 설명합니다. 그들은 웹 페이지를 구조화하기 위해 협력합니다. character count : 159

이 기사는 & lt; Head & gt의 역할에 대해 설명합니다. & lt; Body & Gt; HTML의 태그, 사용자 경험에 미치는 영향 및 SEO 영향. 적절한 구조화는 웹 사이트 기능 및 검색 엔진 최적화를 향상시킵니다.

이 기사는 HTML 태그, 등의 차이점과 시맨틱 대 프리젠 테이션 사용 및 SEO 및 접근성에 미치는 영향에 중점을 둡니다.

기사는 UTF-8에 중점을 둔 HTML에서 문자 인코딩 지정에 대해 논의합니다. 주요 이슈 : 올바른 텍스트 표시 보장, 멍청한 문자 방지 및 SEO 및 접근성 향상.

이 기사는 웹 컨텐츠를 구조화하고 스타일링하는 데 사용되는 다양한 HTML 서식 태그에 대해 논의하여 텍스트 모양에 미치는 영향과 접근성 및 SEO에 대한 시맨틱 태그의 중요성을 강조합니다.

이 기사는 고유성, 목적, CSS 구문 및 특이성에 중점을 둔 HTML의 'ID'와 '클래스'속성의 차이점에 대해 설명합니다. 웹 페이지 스타일링 및 기능에 어떤 영향을 미치는지 설명하고 모범 사례를 제공합니다.

이 기사는 스타일링 및 JavaScript 조작을위한 요소 그룹에서 HTML '클래스'속성의 역할을 고유 한 'ID'속성과 대조합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)
