mirror of
https://github.com/denoland/deno.git
synced 2025-09-26 12:19:12 +00:00
refactor: Event and EventTarget implementations (#4707)
Refactors Event and EventTarget so that they better encapsulate their non-public data as well as are more forward compatible with things like DOM Nodes. Moves `dom_types.ts` -> `dom_types.d.ts` which was always the intention, it was a legacy of when we used to build the types from the code and the limitations of the compiler. There was a lot of cruft in `dom_types` which shouldn't have been there, and mis-alignment to the DOM standards. This generally has been eliminated, though we still have some minor differences from the DOM (like the removal of some deprecated methods/properties). Adds `DOMException`. Strictly it shouldn't inherit from `Error`, but most browsers provide a stack trace when one is thrown, so the behaviour in Deno actually better matches the browser. `Event` still doesn't log to console like it does in the browser. I wanted to get this raised and that could be an enhancement later on (it currently doesn't either).
This commit is contained in:
parent
2b362bef85
commit
fc4819e1e0
40 changed files with 1205 additions and 1120 deletions
|
@ -8,7 +8,6 @@
|
|||
// It sets up runtime by providing globals for `WindowScope` and adds `Deno` global.
|
||||
|
||||
import * as Deno from "./deno.ts";
|
||||
import * as domTypes from "./web/dom_types.ts";
|
||||
import * as csprng from "./ops/get_random_values.ts";
|
||||
import { exit } from "./ops/os.ts";
|
||||
import {
|
||||
|
@ -18,6 +17,7 @@ import {
|
|||
windowOrWorkerGlobalScopeMethods,
|
||||
windowOrWorkerGlobalScopeProperties,
|
||||
eventTargetProperties,
|
||||
setEventTargetData,
|
||||
} from "./globals.ts";
|
||||
import { internalObject } from "./internals.ts";
|
||||
import { setSignals } from "./signals.ts";
|
||||
|
@ -59,9 +59,9 @@ export const mainRuntimeGlobalProperties = {
|
|||
self: readOnly(globalThis),
|
||||
crypto: readOnly(csprng),
|
||||
// TODO(bartlomieju): from MDN docs (https://developer.mozilla.org/en-US/docs/Web/API/WorkerGlobalScope)
|
||||
// it seems those two properties should be availble to workers as well
|
||||
onload: writable(undefined),
|
||||
onunload: writable(undefined),
|
||||
// it seems those two properties should be available to workers as well
|
||||
onload: writable(null),
|
||||
onunload: writable(null),
|
||||
close: writable(windowClose),
|
||||
closed: getterOnly(() => windowIsClosing),
|
||||
};
|
||||
|
@ -78,15 +78,16 @@ export function bootstrapMainRuntime(): void {
|
|||
Object.defineProperties(globalThis, windowOrWorkerGlobalScopeProperties);
|
||||
Object.defineProperties(globalThis, eventTargetProperties);
|
||||
Object.defineProperties(globalThis, mainRuntimeGlobalProperties);
|
||||
setEventTargetData(globalThis);
|
||||
// Registers the handler for window.onload function.
|
||||
globalThis.addEventListener("load", (e: domTypes.Event): void => {
|
||||
globalThis.addEventListener("load", (e) => {
|
||||
const { onload } = globalThis;
|
||||
if (typeof onload === "function") {
|
||||
onload(e);
|
||||
}
|
||||
});
|
||||
// Registers the handler for window.onunload function.
|
||||
globalThis.addEventListener("unload", (e: domTypes.Event): void => {
|
||||
globalThis.addEventListener("unload", (e) => {
|
||||
const { onunload } = globalThis;
|
||||
if (typeof onunload === "function") {
|
||||
onunload(e);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue