-
Notifications
You must be signed in to change notification settings - Fork 16
BOM postMessage
Все свойства объекта window, начинающиеся на "on", позволяют привязать функции к событиям окна
for ( let key in window ) {
key.indexOf("on") === 0 && console.log ( key )
}После "on" в имени свойства следует название типа события
Событие 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 |
| ⏬ |
|---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Приведение типов
- NaN | null | Infinity
- BigInt (ES10)
- Функции
- Методы
- Методы строк
- Методы массивов
- Date ()
Самостоятельная работа
Практика (XSS)
Homework
- Циклы while и do...while
- Циклы for...of и for...in
- Параметры по умолчанию
- Объект function
Практика
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- Размеры и прокрутка элемента
- Event Loop
- async | await
- API
- REST | HATEOAS
- status codes
JSON placeholder-
JSON server
fake chat
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- :not(:defined)
- Shadow DOM
- Custom elements
- Lifecycle hooks
- whenDefined
- <template>
- slot
1
2
3
Homework
- npm
- webpack
Упражнение 1- ES6 модули
Упражнение 2- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
| ⏫ |
|---|

Дополнительно
Справочная инфо
Git Bush
TCP/IP
Коды символов