Angular 报错 Cannot assign to a reference or variable!

情况一:
控件的属性 与 ts 文件里面定义的变量重名了

比如 @Input() key: string;

<div-model key="abc"></div-model>

情况二:
这个问题是应为HTML文件中ngModel绑定了一个变量,却没有给变量赋值导致的。

<input #assembleInquestion id="assembleInputquestion" (click)="question(assembleInquestion,assembleQuestion)"
                name="comb_question" class="wangEditor-container" [(ngModel)]="assembleQuestionName">

错误

assembleQuestionName: string;   //  声明了变量,没有赋值

正确

 assembleQuestionName = '';   //   改为这种声明方式

情况三:
当我想循环一个数组,并把数组的每个元素放到子组件的 [(ngModel)] 中时,出现了这个错误

<app-item *ngFor = "let item of data" [(ngModel)] = "item"></app-item>

问题原因是,ngModel 会去查找 ts文件中的 this.item ,然而我们并没有在ts文件中定义 item。
换句话说,ngModel中传入的值必须是文件的本地的变量,临时的item不会被接受。

最后解决办法是

<app-item *ngFor = "let item of data; let i=index" [(ngModel)] = "data[i]"></app-item>

通过indexOf获取这个item在数组中的 index,然后 直接通过data[index]来传入到ngModel中

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值