window.postMessage() 方法可以安全地實(shí)現(xiàn)跨源通信。通常,對(duì)于兩個(gè)不同頁面的腳本,只有當(dāng)執(zhí)行它們的頁面位于具有相同的協(xié)議(通常為https),端口號(hào)(443為https的默認(rèn)值),以及主機(jī) (兩個(gè)頁面的模數(shù) Document.domain設(shè)置為相同的值) 時(shí),這兩個(gè)腳本才能相互通信。window.postMessage() 方法提供了一種受控機(jī)制來規(guī)避此限制,只要正確的使用,這種方法就很安全。
參考自:https://developer.mozilla.org...
這里的跨源是否指的就是跨域?
查了一下關(guān)于postMessage的使用基本都是iframe向父窗口傳數(shù)據(jù),那是不是不同協(xié)議和不同端口是無法通信的呢?
比如說我在localhost:3000啟動(dòng)一個(gè)頁面,localhost:3500啟動(dòng)一個(gè)頁面,可不可以進(jìn)行通信呢
btn.addEventListener('click', () => {
try {
postMessage('helloWorld','localhost:3000' );
console.info('消息已經(jīng)成功發(fā)送')
} catch (error) {
console.error(error)
}
})
我自己試了一下,會(huì)有報(bào)錯(cuò),但是執(zhí)行時(shí)成功的
這是不是說只能在子頁面或者iframe這種情況下發(fā)送數(shù)據(jù),不同端口不可以通信?
不好意思,審題不清,題主的報(bào)錯(cuò)截圖不影響,是另外的圖標(biāo)請(qǐng)求問題,不影響的,詳細(xì)了解可以戳這里
下面回答題主的其他問題:
可以跨域通信
如果跨域失敗是另一種提示,Access-Control-Allow-Origin,,,,,
跨域包含跨端口,可以自行百度下什么是跨域,大概是:協(xié)議,域名,端口有一個(gè)不同,就是跨域。
現(xiàn)在已經(jīng)弄明白了這個(gè)問題寫下自己的理解,希望可以對(duì)以后遇到相同問題的伙伴一些幫助。此答案不會(huì)給自己采納,歡迎有更好的答案,采納留給更好的答案。
postMessage是可以進(jìn)行跨域通信的。MDN中描述的跨源就是通常意義上的跨域。語法如下:
otherWindow.postMessage(message, targetOrigin, [transfer]);
這里的otherWindow指的是其他窗口的引用,比如iframe的contentWindow屬性、執(zhí)行window.open返回的窗口對(duì)象、或者是命名過或數(shù)值索引的window.frames。
所以此時(shí)的targetOrigin和otherWindow的引用必須是相互匹配的,否則不能進(jìn)行通信。也就是要和誰進(jìn)行通信就要拿到誰的引用。
關(guān)于window.open有一點(diǎn)需要特別注意的就是:要通過window.open獲取引用值,必須是在window.open打開頁面成功打開的情況下才會(huì)返回該窗口的引用,否則返回null。因?yàn)橛械臑g覽器會(huì)處于安全機(jī)制攔截非用戶點(diǎn)擊的自彈出窗口,此時(shí)window.open是無法獲取正常返回值的,postMessage也會(huì)失敗。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。