Angular value与ngValue区别详解
前言
在最近的项目中,需要用到select组件,之前Angular前台都是用现有的封装好的框架,一般都是从Ctrl+c到Ctrl+v的操作然后改一下就可以用,最近使用的Bootstrap原生样式,所以一切都得自己写,但是这样也有好处的,不会受框架的局限性。
组件
ts部分代码:
input输入,output输出
@Input() setcollege(value:College){ this.innerCollege=value; } getcollege():College{ returnthis.innerCollege; } privateinnerCollege:College; @Output() collegeSelect:EventEmitter=newEventEmitter(); ......... publicchange(college:College):void{ this.collegeSelect.emit(college); }
Html:
问题
在发送请求时,向后台发送Post请求时发生错误,并提示状态码为400
出现400
的状态码的错误一般有两种:
1、语义有误,当前请求无法被服务器理解。除非进行修改,否则客户端不应该重复提交这个请求。
2、请求参数有误。
在看一下向后台发送数据为[ObjectObject]
很明显我们这就是第二种请求参数错误,应该是传过去一个College对象,而我们传过去了一个[ObjectObject]
原因
为什么会出现这个原因呢,在大家看来[ObjectObject]是不是也是一个对象?
在控制台打印,发现传过去的College就是[ObjectObject]
为什么会这样显示呢,感觉怪怪的,不是应该显示JSON格式的对象么?
google一下问题迎刃而解,在stackoverflow有详细的解释
[value]="..."仅支持字符串值
[ngValue]="..."支持任何类型
所以value仅支持串字符串,不支持传对象,如果使用value传对象,然而不会得到正确的解析,就得到了我们看到的[ObjectObject]
修改为ngValue
控制台打印:
现在看来是我们想要的数据!!!
在次发送请求,状态码200成功
数据也是正确的!!没有问题!!
总结
感觉之前还是太依赖于框架,没有深究Value与ngValue有什么不同,框架里用Value就直接复制过去,框架都是封装好的,导致现在自己用到了,不知道怎么写的了。
用框架也有好处,既方便又省时间,什么都是现成的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。