Let postMessage on Iframe and Worker more convenient.
-
Iframe iframe example
-
Worker Worker example
-
Iframe data transferable iframe data transferable example
-
Worker data transferable Worker data transferable example
npm install web-messenger
or
yarn add web-messenger
or
pnpm add web-messenger
- Main Window
// main window
import { WebMessengerIframeMain } from "web-messenger";
const messageDispatcher = {
onReady(data) {
console.log(
`[messageDispatcher] post from iframe, method "onReady": `,
data
);
},
parentMethod(params) {
console.log(
`[messageDispatcher] post from iframe, method "parentMethod": `,
params
);
return "result";
},
};
const iframe: HTMLIFrameElement = document.querySelector("#iframeId");
const options: {
originWhiteList?: string[];
postToOrigin?: string;
iframeDom?: HTMLIFrameElement;
} = {
iframeDOM: iframe,
};
const webMessenger = WebMessengerIframeMain.registerMain(
messageDispatcher,
options
);
Post Message to Iframe
webMessenger.postToIframe(callName, data);
webMessenger.postToIframeAwaitResponse(callName, data);
type registerMain
export declare function registerMain<T extends Object>(
messageDispatcher: T,
options?: {
originWhiteList?: string[];
postToOrigin?: string;
iframeDom?: HTMLIFrameElement;
}
): {
postToIframe<T_1>(callName: string, data: T_1): Promise<unknown>;
postToIframeAwaitResponse<T_2>(callName: string, data: T_2): Promise<unknown>;
cleanup(): void;
};
- Iframe window
// iframe window
import { WebMessengerIframeContentWindow } from "web-messenger";
const messageDispatcher = {
ping(data) {
console.log("[messageDispatcher] post from parent, method ping: ", data);
return "pong";
},
};
const options: {
originWhiteList?: string[];
postToOrigin?: string;
} = {};
const webMessenger = WebMessengerIframeContentWindow.registerIframe(
messageDispatcher,
options
);
Post Message to Parent
webMessenger.postToParent(callName, data);
webMessenger.postToParentAwaitResponse(callName, data);
type registerIframe
export declare function registerIframe<T extends Object>(
messageDispatcher: T,
options?: {
originWhiteList?: string[];
postToOrigin?: string;
}
): {
postToParent<T_1>(callName: string, data: T_1): Promise<unknown>;
postToParentAwaitResponse<T_2>(callName: string, data: T_2): Promise<unknown>;
cleanup: () => void;
};
- Main Window
<script src="https://cdn.jsdelivr.net/npm/web-messenger/dist/webMessenger-iframeMain.umd.min.js"></script>
<script>
const webMessenger = WebMessengerIframeMain.registerMain(
messageDispatcher,
options
);
</script>
- Iframe window
<script src="https://cdn.jsdelivr.net/npm/web-messenger/dist/webMessenger-iframeContentWindow.umd.js"></script>
<script>
const webMessenger = WebMessengerIframeContentWindow.registerIframe(
messageDispatcher,
options
);
</script>
- Main Window
// main window
import { WebMessengerWorkerMain } from "web-messenger";
const messageDispatcher = {
onReady(data) {
console.log(
`[messageDispatcher] post from worker, method "onReady": `,
data
);
},
mainMethod(params) {
console.log(
`[messageDispatcher] post from worker, method "mainMethod": `,
params
);
return "result";
},
};
const worker = new Worker("**/**.js");
const options: {
worker: Worker;
} = {
worker,
};
const webMessenger = WebMessengerWorkerMain.registerMain(
messageDispatcher,
options
);
Post Message to Worker
webMessenger.postToWorker(callName, data);
webMessenger.postToWorkerAwaitResponse(callName, data);
type registerMain
export declare function registerMain<T extends Object>(
messageDispatcher: T,
options: {
worker: Worker;
}
): {
postToWorker<T_1>(callName: string, data: T_1): Promise<unknown>;
postToWorkerAwaitResponse<T_2>(callName: string, data: T_2): Promise<unknown>;
cleanup(): void;
};
- Worker scope
// worker scope
import { WebMessengerWorkerScope } from "web-messenger";
const messageDispatcher = {
ping(data) {
console.log("[messageDispatcher] post from main, method ping: ", data);
return "pong";
},
};
const webMessenger = WebMessengerWorkerScope.registerWorker(messageDispatcher);
Post Message to Main
webMessenger.postToMain(callName, data);
webMessenger.postToMainAwaitResponse(callName, data);
type registerWorker
export declare function registerWorker<T extends Object>(
messageDispatcher: T
): {
postToMain<T_1>(callName: string, data: T_1): Promise<unknown>;
postToMainAwaitResponse<T_2>(callName: string, data: T_2): Promise<unknown>;
cleanup: () => void;
};
- Main Window
<script src="https://cdn.jsdelivr.net/npm/web-messenger/dist/webMessenger-workerMain.umd.min.js"></script>
<script>
const webMessenger = WebMessengerWorkerMain.registerMain(
messageDispatcher,
options
);
</script>
- Worker Scope
<script src="https://cdn.jsdelivr.net/npm/web-messenger/dist/webMessenger-workerScope.umd.js"></script>
<script>
const webMessenger =
WebMessengerWorkerScope.registerWorker(messageDispatcher);
</script>
As we know, postMessage can transfer Transferable objects between threads. Transferable objects To make data transferable, we had provided features for two scenarios.
After receiving a call from another side, we sometimes want the data in that response to be transferable.
- Define a function in MessageDispatcher with a name ends with
Transferable
, Such asMyFeatureTransferable
- This function must return a tuple of to elements(
[data, Transferable[]]
), the first one is the data which actually return to the another side, the second is for data transfer(which data can be transferable).
const messageDispatcher = {
MyFeatureTransferable(params) {
const transferableObjects = new ArrayBuffer(10);
return [transferableObjects, [transferableObjects]];
},
};
To send transferable data to another side, we provide "postTo*Transferable" to do so. Such as with Iframe
postToIframeTransferable
,postToIframeTransferableAwaitResponse
,postToParentTransferable
,postToParentTransferableAwaitResponse
Post Message to Iframe data transfer
const webMessenger = WebMessengerIframeMain.registerMain(
messageDispatcher,
options
);
webMessenger.postToIframeTransferable(callName, data);
webMessenger.postToIframeTransferableAwaitResponse(callName, data);
Post Message to Parent data transfer
const webMessenger = WebMessengerIframeContentWindow.registerIframe(
messageDispatcher,
options
);
webMessenger.postToParentTransferable(callName, data);
webMessenger.postToParentTransferableAwaitResponse(callName, data);
Post Message to Worker data transfer
const webMessenger = WebMessengerWorkerMain.registerMain(
messageDispatcher,
options
);
webMessenger.postToWorkerTransferable(callName, data);
webMessenger.postToWorkerTransferableAwaitResponse(callName, data);
Post Message to Main data transfer
const webMessenger = WebMessengerWorkerScope.registerWorker(messageDispatcher);
webMessenger.postToMainTransferable(callName, data);
webMessenger.postToMainTransferableAwaitResponse(callName, data);