angular - 无法分配给引用或变量!(与链接不同的情况)
问题描述
尽管问题的措辞相似,但像这样的答案并不能解决这个问题。
我正在使用自定义组件,并按预期进行以下工作。没有错误,没有警告。
<app-setter [(setting)]="records[0]"></app-setter>
<app-setter [(setting)]="records[1]"></app-setter>
<app-setter [(setting)]="records[2]"></app-setter>
自然,我更喜欢使用这样的模板生成器。
<app-setter *ngFor="let record of records;"
[(setting)]="record"></app-setter>
这会产生以下错误。
无法分配给引用或变量!
谷歌搜索会导致很多关于同一主题的点击 - 组件中的变量与生成的标签的 ID 之间存在冲突。据我所知,这里不是这种情况。我将组件中的唯一字段重命名为记录,我什至没有看到任何 ID 分配给生成的标签。
问题的原因可能是什么?如何进一步诊断?我不确定如何学习两者都不会发生的实际位置(它是compiler.js:xxxx,它告诉我什么都没有)。
编辑
我尝试了以下但没有成功。
<ng-container *ngFor="let record of records;">
<app-setter [(setting)]="record"></app-setter>
</ng-container>
但是,我注意到从香蕉盒中取出香蕉会使错误消失(当然结果是双向绑定被破坏。这有效:
<ng-container *ngFor="let record of records;">
<app-setter [setting]="record"></app-setter>
</ng-container>
它告诉我的很少。但它说明了一些事情,对吧?
组件代码如下所示。
export class AssessmentComponent implements OnInit {
constructor() { }
records: Record[];
ngOnInit() { this.records = [new Record("x", 3), new Record("y", 2)]; }
onAddition(event: Record) { console.log(); }
}
解决方案
您需要像这样使用 *ngFor 循环设置索引。
<app-setter *ngFor="let record of records; let i = index"
[(setting)]="records[i]">
</app-setter>
就像我在其他解决方案的评论中提到的那样,Nikhil 关于使用 ng-container 的建议是一种很好的做法。虽然您不在这里执行此操作,但如果您需要在同一个元素上使用 *ngIf 和 *ngFor,请使用另一个答案中描述的 ng-container,它将产生所需的效果。
推荐阅读
- xamarin - 任务因 Xamarin.Forms 中的错误而失败?
- ios - AVCaptureVideoPreviewLayer 在调整大小时创建 2 个视图
- docker - 将正在运行的 docker 容器添加到虚拟网络中
- javascript - 如何在这篇文章中制作变量,全球?
- ruby - 使用 Flickr API 下载我自己的私人相册
- javascript - 形状错误后的fabric.js免费绘图
- docker - 通过缓存模式拉取的私有 Docker 注册表返回“无效的授权凭据”
- ios - 如何知道哪个版本的 cocoapods 适合我的 xcode
- git - git pull 总是打开一个新的提交窗口
- vba - 从报告中打开表格