首页 > 解决方案 > 类型“未知”不可分配给类型“键盘事件”.ts (2345)

问题描述

我正在学习 TypeScript 和 Angular,并且在我的书中遇到了一个无法编译的示例。恐怕我不知道如何解决这个问题。

这是无法编译的函数:

ngOnInit(): void {
    const logger = fromEvent(this.input.nativeElement, 'keyup');
    logger.pipe(
      map((evt: KeyboardEvent) => evt.key.charCodeAt(0)),
      filter(code => {
        if (this.numeric) {
          return !(code > 31 && (code < 48 || code > 57));
        }
        return true;
      }),
      tap(digit => this.keys += String.fromCharCode(digit))
    ).subscribe();
  }

不会编译的特定行是:

map((evt: KeyboardEvent) => evt.key.charCodeAt(0)),

我看到以下错误:

Argument of type 'OperatorFunction<KeyboardEvent, number>' is not assignable to parameter of type 'OperatorFunction<unknown, number>'.
  Type 'unknown' is not assignable to type 'KeyboardEvent'.ts(2345)

标签: angulartypescripteventskeyboard

解决方案


只是告诉 ts 这个流将是键盘事件流

const logger = fromEvent<KeyboardEvent>(this.input.nativeElement, 'keyup');

这个<Type>参数使记录器Observable<KeyboardEvent>和 ts 不会抱怨它


推荐阅读