angular - 未定义的验证不起作用-角度 11
问题描述
我有一个组件,我订阅了一个 Customer 对象,这个客户有一个电话是字符串,但它可以是未定义的,因为在数据库中是空的,所以后端不发送它。这就是为什么我需要在打印 html 中的数据之前进行验证。我尝试为什么简单的 if(this.customer.movilPhone) 但我收到一条错误消息:无法读取未定义的属性“movilPhone”。然后我尝试了 if (this.customer.movilPhone !== 'undefined') 但我也遇到了同样的错误。我使用的第一个选项应该可以工作,为什么没有?提前致谢 :)
我的代码是这个:
export interface CustomerModel {
dateOfBirth?: string;
country?: string;
firstName?: string;
lastName?: string;
city?: string;
movilPhone?: string;
email?: string;
}
export class AppointmentComponent implements OnInit, OnDestroy {
public destroyed = new Subject<any>();
customer: CustomerModel;
constructor(private readonly translate: TranslateService,
private readonly sharingDataService: SharingDataService,
private readonly router: Router,
private readonly activatedRoute: ActivatedRoute,
private readonly breakpointObserver: BreakpointObserver,
private readonly customerService: CustomerService) {
}
getCustomerData(): void{
this.customerService.getCustomer().subscribe(data => this.customer = data);
this.createArrayOfPhones();
}
isValid(telephone: string): boolean {
return typeof telephone !== 'undefined';
}
createArrayOfPhones(): void {
const telephones = {} as Array<string>;
this.customer.mobilePhone;
if (this.customer.movilPhone) { // Not Works
telephones.push(this.customer.movilPhone);
}
console.log('Before');
if (telephones) { // Works
for (let i = 0; i < telephones.length; i++){
console.log('Telephones ' + telephones[i]);
}
}
}
ngOnDestroy(): void {
this.destroyed.next();
this.destroyed.complete();
this.destroyed.unsubscribe();
}
}
解决方案
问题:
this.customer.movilPhone
抛出错误,因为this.customer
没有赋值。预计是null
或undefined
。
解决方案:
您需要确保this.customer
分配了值然后才访问 您可以使用Typescript Optional Chainingthis.customer.movilPhone.
来实现它。
if (this.customer?.movilPhone) {
telephones.push(this.customer.movilPhone);
}
推荐阅读
- android - 无法在 Xamarin Android 应用程序中加载用于 ImageSharp 的字体
- c# - NodaTime Instant 的序列化不适用于 Asp.Net Core web api 和 OData
- c# - 如何使用 Selenium 和 Firefox 自动下载可执行文件
- windows - 如何从 Microsoft 为我的 Windows 10 微型过滤器驱动程序签名
- php - 带有子字符串过滤器的 Sql 查询以更新数据
- testing - 维护与回归测试
- python - 具有时变截止频率的低通滤波器,使用 Python
- php - 按 ASC 顺序排序
- kubernetes - kubernetes 可能同时运行不同的图像,这会导致问题吗?
- php - 如何在php中获取和存储菜单值