今天就跟大家聊聊有关value与ngValue如何在Angular中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
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
出现 400
的状态码的错误一般有两种:
1、语义有误,当前请求无法被 服务器 理解。除非进行修改,否则客户端不应该重复提交这个请求。
2、请求参数有误。
在看一下向后台发送数据为 [Object Object]
很明显我们这就是第二种请求参数错误,应该是传过去一个 College
对象,而我们传过去了一个 [Object Object]
原因
为什么会出现这个原因呢,在大家看来 [Object Object]
是不是也是一个对象?
在控制台打印,发现传过去的 College
就是 [Object Object]
为什么会这样显示呢,感觉怪怪的,不是应该显示 JSON
格式的对象么?
google
一下问题迎刃而解,在 stackoverflow 有详细的解释
[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>
控制台打印:
现在看来是我们想要的数据!!!
在次发送请求,状态码 200
成功
看完上述内容,你们对value与ngValue如何在Angular中使用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。