Как добавить свойство Target в новый MouseEvent? - PullRequest
0 голосов
/ 25 февраля 2019

Я пытаюсь отправить событие contextMenu и заметил, что в свойстве MouseEvent; interface for TypeScript there isn't a target`, которое находится в документации contextMenu .

мой фрагмент TS

const emulatedMouseEvent: MouseEvent = new MouseEvent('contextmenu', {
  bubbles: true,
  altKey: event.args[0],
  ctrlKey: event.args[1],
  shiftKey: event.args[2]
})
this.webview.dispatchEvent(emulatedMouseEvent)

Ошибка TS при попытке добавить target: event.args[3]

Argument of type '{ bubbles: true; altKey: any; ctrlKey: any; shiftKey: any; target: any; }' is not assignable to parameter of type 'MouseEventInit'.
  Object literal may only specify known properties, and 'target' does not exist in type 'MouseEventInit'.ts(2345)

и в lib.dom.d.ts

interface MouseEvent extends UIEvent {
    readonly altKey: boolean;
    readonly button: number;
    readonly buttons: number;
    readonly clientX: number;
    readonly clientY: number;
    readonly ctrlKey: boolean;
    /** @deprecated */
    readonly fromElement: Element;
    readonly layerX: number;
    readonly layerY: number;
    readonly metaKey: boolean;
    readonly movementX: number;
    readonly movementY: number;
    readonly offsetX: number;
    readonly offsetY: number;
    readonly pageX: number;
    readonly pageY: number;
    readonly relatedTarget: EventTarget;
    readonly screenX: number;
    readonly screenY: number;
    readonly shiftKey: boolean;
    /** @deprecated */
    readonly toElement: Element;
    /** @deprecated */
    readonly which: number;
    readonly x: number;
    readonly y: number;
    getModifierState(keyArg: string): boolean;
    initMouseEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, ctrlKeyArg: boolean, altKeyArg: boolean, shiftKeyArg: boolean, metaKeyArg: boolean, buttonArg: number, relatedTargetArg: EventTarget | null): void;
}

declare var MouseEvent: {
    prototype: MouseEvent;
    new(typeArg: string, eventInitDict?: MouseEventInit): MouseEvent;
};

конечно, в документации MouseEvent нет свойства Target, но я не знаю, как я должен создать это contextmenu событие с целевым свойством, которое существуетна самом событии, но не на MouseEvent, конечно.

Редактировать: не является дубликатом, этот вопрос касается Target, возвращаемого null, и решение для этого вопроса недостаточно.

1 Ответ

0 голосов
/ 25 февраля 2019

MouseEvent extends UIEvent, UIEvent extends Event, событие имеет цель свойство.

...