In addition to Weibo, there is also WeChat
Please pay attention
WeChat public account
Shulou
2025-01-16 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Development >
Share
Shulou(Shulou.com)06/03 Report--
This article is about the sample analysis of window.postMessage and cross-domain in HTML5. The editor thinks it is very practical, so share it with you as a reference and follow the editor to have a look.
Talking about the same origin policy of the browser, that is, the methods and properties of preventing pages from different domains from accessing each other, and expounding the solutions to solve the cross-domain problem of the same origin policy: sub-domain agent, JSONP, CORS. This article will elaborate on HTML5 window.postMessage. With postMessage API, documents can communicate across domains in a secure and controllable way, and third-party JavaScript code can also communicate with external documents loaded in iframe.
HTML5 window.postMessage API
HTML5 window.postMessage is a secure, event-based message API.
PostMessage sends messages
You can send a message by calling the postMessage method in the source window where you need to send it.
Source window
The source window can be a global window object or the following types of windows:
Iframe in the document window:
Var iframe = document.getElementById ('my-iframe'); var win = iframe.documentWindow
Pop-up window opened by JavaScript:
Var win = window.open ()
Parent window of the current document window:
Var win = window.parent
Open the window of the current document:
Var win = window.opener ()
Once the source window object is found, you can call postMessage API to send a message to the target window:
``win.postMessage ('Hello',' ttp://jhssdemo.duapp.com/'); "
The postMessage function takes two parameters: the first is the message to be sent, and the second is the source of the source window.
Note: messages can be received only if the source of the destination window matches the value of the source parameter passed in the postMessage function.
Receive postMessage messages
To receive the previous message sent by the source window through postMessage, simply register the message event in the target window and bind the event listener function to get the message in the function parameters.
_ window.onload = function () {var text = document.getElementById ('txt'); function receiveMsg (e) {console.log ("Got a message!"); console.log ("nMessage:" + e.data); console.log ("nOrigin:" + e.origin); / / console.log ("Source:" + e.source) Text [XSS _ clean] = "Got a message!
+ "Message:" + e.data + "
Origin: "+ e.girls;} if (window.addEventListener) {/ / register the message event for the window and bind the listening function window.addEventListener ('message', receiveMsg, false);} else {window.attachEvent (' message', receiveMsg);}}
The message event listener function takes a parameter, an instance of the Event object, which has three properties:
Specific messages sent by data
Origin sends message source
Window object reference of the source send message window
Description
You can set the second parameter of the postMessage function to *, which skips checking the source of the message when sending a cross-domain message.
PostMessage can only send string information.
Example
Source window
Html5 postMessage # otherWin {width: 600px; height: 400px; background-color: # cccccc } open send _ window.onload = function () {var btn = document.getElementById ('btn'); var btn_send = document.getElementById (' send'); var sendBtn = document.getElementById ('sendMessage') Var win; btn.onclick = function () {/ / Open the target window for receiving messages through window.open win = window.open ('http://jhssdemo.duapp.com/demo/h6_postmessage/win.html',' popUp') } btn_send.onclick = function () {/ / send data win.postMessage ('Hello',' http://jhssdemo.duapp.com/');) to the child window through postMessage } function sendIt (e) {/ / send data document.getElementById ("otherWin"). ContentWindow .postMessage (document.getElementById ("message"). Value, "http://jhssdemo.duapp.com/");" to the child window through postMessage } sendBtn.onclick = function (e) {sendIt (e);};}
Target window win.html
Html5 postMessage # txt {width: 500px; height: 300px; background-color: # cccccc;} The New Window
_ window.onload = function () {var text = document.getElementById ('txt'); / / listener function, which takes a parameter-- Event event object function receiveMsg (e) {console.log ("Got a message!"); console.log ("nMessage:" + e.data) Console.log ("nOrigin:" + e.origin); text[ XSS _ clean] = "Got a message!
+ "Message:" + e.data + "
Origin: "+ e.girls;} if (window.addEventListener) {/ / register the message event for window and bind the listening function window.addEventListener ('message', receiveMsg, false);} else {window.attachEvent (' message', receiveMsg);}} Thank you for reading! This is the end of this article on "sample analysis of window.postMessage and cross-domain in HTML5". I hope the above content can be of some help to you, so that you can learn more knowledge. if you think the article is good, you can share it for more people to see!
Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.
Views: 0
*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.
Continue with the installation of the previous hadoop.First, install zookooper1. Decompress zookoope
"Every 5-10 years, there's a rare product, a really special, very unusual product that's the most un
© 2024 shulou.com SLNews company. All rights reserved.