前言
在最近的项目中,需要用到 select
组件,之前 Angular
前台都是用现有的封装好的框架,一般都是从 Ctrl+c
到 Ctrl+v
的操作然后改一下就可以用,最近使用的 Bootstrap
原生样式,所以一切都得自己写,但是这样也有好处的,不会受框架的局限性。
组件
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
出现 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
有什么不同,框架里用 Value
就直接复制过去,框架都是封装好的,导致现在自己用到了,不知道怎么写的了。
用框架也有好处,既方便又省时间,什么都是现成的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 三国志8重制版恶名怎么消除 恶名影响与消除方法介绍
- 模拟之声慢刻CD《柏林之声5》2019[原抓WAV+CUE]
- AlexandraSoumm-Parisestunefte(2024)[24Bit-96kHz]FLAC
- 李嘉《国语转调1》[天王唱片][WAV整轨]
- 不是哥们 这都能跑?网友展示用720显卡跑《黑神话》
- 玩家自制《黑神话:悟空》亢金星君3D动画 现代妆容绝美
- 大佬的审美冲击!《GTA6》环境设计师展示最新作品
- 纪晓君.2001-野火·春风【魔岩】【WAV+CUE】
- 汪峰.2005-怒放的生命【创盟音乐】【WAV+CUE】
- 群星.1995-坠入情网【宝丽金】【WAV+CUE】
- 群星《谁杀死了Hi-Fi音乐》涂鸦精品 [WAV+CUE][1G]
- 群星1998《宝丽金最精彩98》香港首版[WAV+CUE][1G]
- 汪峰《也许我可以无视死亡》星文[WAV+CUE][1G]
- 李嘉-1991《国语转调2》[天王唱片][WAV整轨]
- 蔡琴2008《金声回忆录101》6CD[环星唱片][WAV整轨]