2020-05-07 00:21:13 +02:00
|
|
|
## Program lifecycle
|
|
|
|
|
|
|
|
Deno supports browser compatible lifecycle events: `load` and `unload`. You can
|
|
|
|
use these events to provide setup and cleanup code in your program.
|
|
|
|
|
2020-05-18 14:53:25 -05:00
|
|
|
Listeners for `load` events can be asynchronous and will be awaited. Listeners
|
|
|
|
for `unload` events need to be synchronous. Both events cannot be cancelled.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
Example:
|
|
|
|
|
2020-05-27 03:12:02 +01:00
|
|
|
**main.ts**
|
|
|
|
|
2020-05-10 03:09:42 +02:00
|
|
|
```ts
|
2020-05-07 00:21:13 +02:00
|
|
|
import "./imported.ts";
|
|
|
|
|
|
|
|
const handler = (e: Event): void => {
|
|
|
|
console.log(`got ${e.type} event in event handler (main)`);
|
|
|
|
};
|
|
|
|
|
|
|
|
window.addEventListener("load", handler);
|
|
|
|
|
|
|
|
window.addEventListener("unload", handler);
|
|
|
|
|
|
|
|
window.onload = (e: Event): void => {
|
|
|
|
console.log(`got ${e.type} event in onload function (main)`);
|
|
|
|
};
|
|
|
|
|
|
|
|
window.onunload = (e: Event): void => {
|
|
|
|
console.log(`got ${e.type} event in onunload function (main)`);
|
|
|
|
};
|
|
|
|
|
2020-05-15 17:27:38 +03:00
|
|
|
console.log("log from main script");
|
2020-05-27 03:12:02 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
**imported.ts**
|
2020-05-15 17:27:38 +03:00
|
|
|
|
2020-05-27 03:12:02 +01:00
|
|
|
```ts
|
2020-05-07 00:21:13 +02:00
|
|
|
const handler = (e: Event): void => {
|
|
|
|
console.log(`got ${e.type} event in event handler (imported)`);
|
|
|
|
};
|
|
|
|
|
|
|
|
window.addEventListener("load", handler);
|
|
|
|
window.addEventListener("unload", handler);
|
|
|
|
|
|
|
|
window.onload = (e: Event): void => {
|
|
|
|
console.log(`got ${e.type} event in onload function (imported)`);
|
|
|
|
};
|
|
|
|
|
|
|
|
window.onunload = (e: Event): void => {
|
|
|
|
console.log(`got ${e.type} event in onunload function (imported)`);
|
|
|
|
};
|
|
|
|
|
|
|
|
console.log("log from imported script");
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that you can use both `window.addEventListener` and
|
|
|
|
`window.onload`/`window.onunload` to define handlers for events. There is a
|
2020-05-18 14:53:25 -05:00
|
|
|
major difference between them, let's run the example:
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
```shell
|
|
|
|
$ deno run main.ts
|
|
|
|
log from imported script
|
|
|
|
log from main script
|
|
|
|
got load event in onload function (main)
|
|
|
|
got load event in event handler (imported)
|
|
|
|
got load event in event handler (main)
|
|
|
|
got unload event in onunload function (main)
|
|
|
|
got unload event in event handler (imported)
|
|
|
|
got unload event in event handler (main)
|
|
|
|
```
|
|
|
|
|
|
|
|
All listeners added using `window.addEventListener` were run, but
|
2020-05-17 19:24:39 +02:00
|
|
|
`window.onload` and `window.onunload` defined in `main.ts` overrode handlers
|
2020-05-07 00:21:13 +02:00
|
|
|
defined in `imported.ts`.
|
2020-05-27 03:12:02 +01:00
|
|
|
|
|
|
|
In other words, you can register multiple `window.addEventListener` `"load"` or
|
|
|
|
`"unload"` events, but only the last loaded `window.onload` or `window.onunload`
|
|
|
|
events will be executed.
|