Skip to content

BOM postMessage

garevna edited this page Jul 19, 2019 · 1 revision

🎓 Browser Object Model

🎓 window.postMessage()

⚠️ Для понимания этого раздела нужно познакомиться с событийной моделью браузера


Все свойства объекта window, начинающиеся на "on", позволяют привязать функции к событиям окна

for ( let key in window ) {
    key.indexOf("on") === 0 && console.log ( key )
}

После "on" в имени свойства следует название типа события

🎓 onmessage

Событие message возникает при получении окном сообщения из другого открытого окна браузера
Если на свойство onmessage "повесить" функцию ( callback ), то эта функция будет вызвана при наступлении события message

window.onmessage = function ( event ) {
    console.log ( event )
}

Предположим, текущее окно получило сообщение "Hello, I'm listening to you"
Теперь будет вызван обработчик события и в консоли мы увидим примерно следующее:

▼ MessageEvent {isTrusted: true, data: "Hello, I'm listening to you", origin: "null", lastEventId: "", source: Window, …}
    bubbles: false
    cancelBubble: false
    cancelable: false
    composed: false
  ► currentTarget: Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, parent: Window, …}
    data: "Hello, I'm listening to you"
    defaultPrevented: false
    eventPhase: 0
    isTrusted: true
    lastEventId: ""
    origin: "null"
  ► path: [Window]
  ► ports: []
    returnValue: true
  ► source: Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, parent: Window, …}
  ► srcElement: Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, parent: Window, …}
  ► target: Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, parent: Window, …}
    timeStamp: 5.620000010821968
    type: "message"
    userActivation: null
  ► __proto__: MessageEvent

Как мы видим, переданный обработчику объект события несет в себе много полезной информации
В частности, мы можем узнать, из какого окна пришло сообщение ( свойство source объекта event )
Текст сообщения мы получим в свойстве data объекта event
В свойстве target объекта event будет ссылка на окно ( вкладку ), которое получило сообщение

Пришло время разобраться, как отправить сообщение из одной открытой вкладки бразера в другую


postMessage() - метод, позволяющий послать сообщение из одного открытого окна в другое открытое окно браузера

Пример

Откройте пустую вкладку ( в адресной строке браузера наберите about:blank )
Установим значение "parentWin" для свойства name активного окна ( вкладки )
Для этого в консоли активного окна ( вкладки ) выполним код:

window.name = "parentWin"

Теперь установливаем обработчика события message активной вкладки ( анонимную функцию связываем со свойством onmessage объекта window ):

window.onmessage = function ( event ) {
    this.document.write ( `<h3>${this.name}</h3><p>Message received</p><b><em>${event.data}</em></b>` )
}

⚠️ Обработчик события должен всегда получать объект события
( для этого нужно устанавливать формальный параметр обработчика )
В нашем примере формальный параметр имеет идентификатор event, и внутри анонимной функции-обработчика в этой переменной будет ссылка на объект события, которое привело к вызову этой функции

Теперь откроем новое ( "дочернее" ) окно ( вкладку ):

var childWin = window.open( "about:blank", "childWin" )

Как видите, ссылку на новую открытую вкладку мы поместили в переменную childWin
Установим обработчика события onmessage новой вкладки:

childWin.onmessage = function ( event ) {
    childWin.document.write ( `<h3>${this.name}</h3><p>I've received the message from ${event.source.name}</p><b><em>${event.data}</em></b>` )
    event.source.postMessage( "Wecome any time, my dear!", "*" )
}

При получении сообщения вкладка выведет его на страницу, указав при этом свое имя ( this.name ) имя окна, отправившего сообщение ( event.source.name )
Кроме того, вкладка отправит сообщение в ответ с текстом "Wecome any time, my dear!"

Нам осталось только отправить сообщение новой открытой нами вкладке:

childWin.postMessage( "Hello, I'm listening to you", "*" )

Полный код примера

window.name = "parentWin"

window.onmessage = function ( event ) {
    this.document.write ( `<h3>${this.name}</h3><p>Message received</p><b><em>${event.data}</em></b>` )
}

let childWin = window.open( "about:blank", "childWin" )

childWin.onmessage = function ( event ) {
    childWin.document.write ( `<h3>${this.name}</h3><p>I've received the message from ${event.source.name}</p><b><em>${event.data}</em></b>` )
    event.source.postMessage( "Wecome any time, my dear!", "*" )
}

childWin.postMessage( "Hello, I'm listening to you", "*" )

© Irina H.Fylyppova 2018
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав


Новая версия


1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
16 17 18 19

Занятие 1

⤵️

Занятие 2

⤴️ ⤵️

Занятие 3

⤴️ ⤵️

Занятие 4

⤴️ ⤵️

Занятие 5

⤴️ ⤵️

Занятие 6

⤴️ ⤵️

Занятие 7

⤴️ ⤵️

Занятие 8

⤴️ ⤵️

Занятие 9

⤴️ ⤵️

Занятие 10

⤴️ ⤵️

Занятие 11

⤴️ ⤵️

Занятие 12

⤴️ ⤵️

Занятие 13

⤴️ ⤵️

Занятие 14

⤴️ ⤵️

Занятие 15

⤴️ ⤵️

Занятие 16

⤴️ ⤵️

Занятие 17

⤴️ ⤵️

Занятие 18

⤴️ ⤵️

Занятие 19

⤴️ ⤵️

⤴️

ico20 Дополнительно
dir-20 Справочная инфо

Clone this wiki locally