欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Angular value与ngValue区别详解

程序员文章站 2022-03-07 09:40:25
前言 在最近的项目中,需要用到 select 组件,之前 angular 前台都是用现有的封装好的框架,一般都是从 ctrl+c 到 ctrl+v 的操作然后改一下就可以用,最近使用...

前言

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

Angular value与ngValue区别详解

组件

ts部分代码:

input 输入, output 输出

@input()
 set college(value: college) {
  this.innercollege = value;
 }

 get college(): college {
  return this.innercollege;
 }

 private innercollege: college;

 @output()
 collegeselect: eventemitter<college> = new eventemitter();
 
 .........
 
  public change(college: college): void {
  this.collegeselect.emit(college);
 }

html:

<select [comparewith]="comparedwithid" class="form-control" [(ngmodel)]="college" (change)="change(college)">
 <option value="-1" >请选择学院...</option>
 <option *ngfor="let _college of colleges" [value]="_college">{{_college.name}}</option>
</select>

问题

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

Angular value与ngValue区别详解

出现 400

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

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

2、请求参数有误。

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

Angular value与ngValue区别详解

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

原因

为什么会出现这个原因呢,在大家看来 [object object] 是不是也是一个对象?

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

Angular value与ngValue区别详解

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

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

Angular value与ngValue区别详解

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

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

修改为ngvalue

<select [comparewith]="comparedwithid" class="form-control" [(ngmodel)]="college" (change)="change(college)">
 <option value="-1" >请选择学院...</option>
 <option *ngfor="let _college of colleges" [ngvalue]="_college">{{_college.name}}</option>
</select>

控制台打印:

Angular value与ngValue区别详解

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

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

Angular value与ngValue区别详解

Angular value与ngValue区别详解

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

总结

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

用框架也有好处,既方便又省时间,什么都是现成的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。