角度错误 TS2531:对象可能为“空”

Nou*_*wla 21 html angularjs typescript angular

所以我有一个 Component.html,其中包含如下输入:

<input type="text" (change) = "setNewUserName($event.target.value)"/>
Run Code Online (Sandbox Code Playgroud)

组件.ts 是:

import { Component } from "@angular/core";
@Component({
    selector : 'app-users-list',
    templateUrl : './usersList.component.html'
})
export class UsersListComponent 
{
   setNewUserName (userName : string): void {
       console.log('setNewUserName', userName)
   }
}
Run Code Online (Sandbox Code Playgroud)

最后 module.ts 是:

@NgModule ({
    declarations: [UsersListComponent],
    imports : [CommonModule],
    exports: [UsersListComponent]
})
export class UsersListModule {}
Run Code Online (Sandbox Code Playgroud)

运行服务器时,出现如下错误:

error TS2531: Object is possibly 'null'.

1 <input type="text" (change) = "setNewUserName($event.target.value)"/>
                                                              ~~~~~
Run Code Online (Sandbox Code Playgroud)

Mic*_*l D 34

你在使用 Angular Ivy 吗?最有可能的是由于Ivy AOT 中的模板类型检查

尽管如此,还是有多种选择

选项 1:将事件作为参数发送

<input type="text" (change) = "setNewUserName($event)"/>
Run Code Online (Sandbox Code Playgroud)
export class UsersListComponent {
    setNewUserName(event: Event): void {
      console.log('setNewUserName', (event.target as HTMLTextAreaElement).value);
    }
}
Run Code Online (Sandbox Code Playgroud)

选项 2:使用模板引用变量

<input #userName type="text" (change) = "setNewUserName(userName.value)"/>
Run Code Online (Sandbox Code Playgroud)
export class UsersListComponent {
   setNewUserName (userName : string): void {
       console.log('setNewUserName', userName)
   }
}
Run Code Online (Sandbox Code Playgroud)

选项 3:使用禁用类型检查$any()

<input type="text" (change) = "setNewUserName($any($event.target).value)"/>
Run Code Online (Sandbox Code Playgroud)
export class UsersListComponent {
   setNewUserName (userName : string): void {
       console.log('setNewUserName', userName)
   }
}
Run Code Online (Sandbox Code Playgroud)

选项 4:模板驱动或反应式形式

使用模板驱动反应式表单来获取输入值。在我看来,这将是最优雅的方法。

更新:添加禁用类型检查


小智 8

尝试这个

setNewUserName($any($event.target).value);
Run Code Online (Sandbox Code Playgroud)

会起作用的