[Angular TypeScript报错]Cannot assign to read only property ‘outwardcolor‘ of object ‘[object Object]‘

事情发生过程
用动态路由从一个组件传一个对象到另一个组件接收时发生的错误
源码:
对象 selected

export interface selected {
  model?: string;
  outwardcolor?: string;
  outwardwheel?: string;
  interior?: string;
  features?: string;
  pay?: string;
}

接收方的ts文件(只有重点部分)

  public chosen: selected = <any>{};
  constructor(private router: Router, private arouter: ActivatedRoute) { }

  ngOnInit(): void {
    this.arouter.params.subscribe((data: selected) =>{
      this.chosen = data;
    });
  public selectColor(color: string){
	this.chosen.outwardcolor = color;
	}

当我调用这个函数时 问题就来了

在这里插入图片描述

这个问题的玄学之处在于 在初始化赋值后 初始化结束前 它还是个对象

	this.chosen.outwardcolor = 'color';

这还是成立的

但是一到方法中这个对象就变成了 object
object 与json 对象的差别在于有没有外面那层{}

所以解决方法就是
在给它设值之前给它加个{}

    let o ={};
    let newchosen = Object.assign(o, this.chosen);

此时 这个newchosen 又重新变成了对象
这个时候在给他赋值就没问题了

newchosen.outwarcolor = color ;

this.chosen 与 newchosen 在F12中看似相近 但其实是有差的!!!!

在这里插入图片描述

问题解决

感谢我的老师,and

引用文章: https://blog.csdn.net/tooby/article/details/84902746

相关文章

我最大的一个关于TypeScript的问题是,它将原型的所有方法(无...
我对React很新,我正在尝试理解子组件之间相互通信的简洁方法...
我有一个非常简单的表单,我将用户电子邮件存储在组件的状态,...
我发现接口非常有用,但由于内存问题我需要开始优化我的应用程...
我得到了一个json响应并将其存储在mongodb中,但是我不需要的...
我试图使用loadsh从以下数组中获取唯一类别,[{"listing...