value与ngValue区别

前言

在最近的项目中,需要用到select组件,之前Angular前台都是用现有的封装好的框架,一般都是从Ctrl+cCtrl+v的操作然后改一下就可以用,最近使用的Bootstrap原生样式,所以一切都得自己写,但是这样也有好处的,不会受框架的局限性。

value与ngValue区别_第1张图片

组件

ts部分代码:

input输入,output输出

@Input()
  set college(value: College) {
    this.innerCollege = value;
  }

  get college(): College {
    return this.innerCollege;
  }

  private innerCollege: College;

  @Output()
  collegeSelect: EventEmitter = new EventEmitter();
  
  .........
  
   public change(college: College): void {
    this.collegeSelect.emit(college);
  }

Html:

问题

在发送请求时,向后台发送Post请求时发生错误,并提示状态码为400

value与ngValue区别_第2张图片

出现 400的状态码的错误一般有两种:

1、语义有误,当前请求无法被服务器理解。除非进行修改,否则客户端不应该重复提交这个请求。

2、请求参数有误。

在看一下向后台发送数据为[Object Object]

value与ngValue区别_第3张图片

很明显我们这就是第二种请求参数错误,应该是传过去一个College对象,而我们传过去了一个[Object Object]

原因

在控制台打印,发现传过去的College就是[Object Object]

image.png

为什么会这样显示呢,感觉怪怪的,不是应该显示JSON格式的对象么?

google一下问题迎刃而解,在stackoverflow有详细的解释

value与ngValue区别_第4张图片

[value]="..." 仅支持字符串值
[ngValue]="..." 支持任何类型

所以value仅支持串字符串,不支持传对象,如果使用value传对象,然而不会得到正确的解析,就得到了我们看到的[Object Object]

修改为ngValue

控制台打印:

value与ngValue区别_第5张图片

现在看来是我们想要的数据!!!

在次发送请求,状态码 200 成功

value与ngValue区别_第6张图片

image.png

数据也是正确的!!没有问题!!

总结

感觉之前还是太依赖于框架,没有深究ValuengValue有什么不同,框架里用Value就直接复制过去,框架都是封装好的,导致现在自己用到了,不知道怎么写的了。

用框架也有好处,既方便又省时间,什么都是现成的。
也有不好的地方,导致总也不写,就不会写了,总想着有没有现成的。

你可能感兴趣的:(angular)