Angular - 类型'string'不能赋值为'boolean'

时间:2017-07-21 21:00:14

标签: angular typescript angular-cli

Angular 4.3.1
Angular CLI 1.2.3
打字稿2.3.4

组件手稿文件:

public saveName: string;
public overwrite: boolean;

以下标记失败,当我运行ng build --prod

时,类型'字符串'无法指定为类型'布尔'
<span>{{!overwrite || saveName}}</span>

OR

<button *ngIf="!overwrite && saveName">Save</button>

但是,它可以正常使用以下内容:

<span>{{saveName || !overwrite}}</span>
<span>{{overwrite || saveName}}</span>
<button *ngIf="saveName && !overwrite">Save</button>
<button *ngIf="overwrite && saveName">Save</button>

为什么我会收到该错误?
更具体地说,为什么只有当我在字符串之前有一个否定的布尔值时才出现该错误?

1 个答案:

答案 0 :(得分:10)

尝试*ngIf="!overwrite && !!saveName"saveName转换为布尔值

TypeScript为错误提供的原因大致是:您使用的字符串应该使用布尔值。

我认为它只发生在那种情况下的原因是因为如果你有true || anything只会评估第一个(因为如果第一个是真的,整个表达式将为真,无论其余的是什么)