The MessagePort interface of the Channel Messaging API represents one of the two ports of a MessageChannel, allowing messages to be sent from one port and listening out for them arriving at the other.
onmessage: ((this: MessagePort,ev: MessageEvent,) => any) | nullonmessageerror: ((this: MessagePort,ev: MessageEvent,) => any) | nullclose(): voidDisconnects the port, so that it is no longer active.
postMessage(message: any,transfer: Transferable[],): voidPosts a message through the channel. Objects listed in transfer are transferred, not just cloned, meaning that they are no longer usable on the sending side.
Throws a "DataCloneError" DOMException if transfer contains duplicate objects or port, or if message could not be cloned.
postMessage(message: any,options?: StructuredSerializeOptions,): voidstart(): voidBegins dispatching messages received on the port. This is implicitly called
when assigning a value to this.onmessage.
addEventListener<K extends keyof MessagePortEventMap>(type: K,listener: (this: MessagePort,ev: MessagePortEventMap[K],) => any,options?: boolean | AddEventListenerOptions,): voidaddEventListener(type: string,listener: EventListenerOrEventListenerObject,options?: boolean | AddEventListenerOptions,): voidremoveEventListener<K extends keyof MessagePortEventMap>(type: K,listener: (this: MessagePort,ev: MessagePortEventMap[K],) => any,options?: boolean | EventListenerOptions,): voidremoveEventListener(): void