Angular value与ngValue区别详解


Posted in Javascript onNovember 27, 2019

前言

在最近的项目中,需要用到 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 一下问题迎刃而解,在 stackoverflow 有详细的解释

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 就直接复制过去,框架都是封装好的,导致现在自己用到了,不知道怎么写的了。

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

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

Javascript 相关文章推荐
js+css使DIV始终居于屏幕中间 左下 左上 右上 右下的代码集合
Mar 10 Javascript
THREE.JS入门教程(5)你应当知道的十件事
Jan 24 Javascript
js时间日期格式化封装函数
Dec 02 Javascript
jQuery实现点击表格单元格就可以编辑内容的方法【测试可用】
Aug 01 Javascript
JQuery手速测试小游戏实现思路详解
Sep 20 Javascript
通过封装scroll.js 获取滚动条的值
Jul 13 Javascript
vue+vue-router转场动画的实例代码
Sep 01 Javascript
基于Vue实现图片在指定区域内移动的思路详解
Nov 11 Javascript
react 组件传值的三种方法
Jun 03 Javascript
微信小程序分包加载代码实现方法详解
Sep 23 Javascript
JavaScript原生数组函数实例汇总
Oct 14 Javascript
JS实现点击掉落特效
Jan 29 Javascript
原生js实现二级联动菜单
Nov 27 #Javascript
微信小程序wxml列表渲染原理解析
Nov 27 #Javascript
原生js实现下拉选项卡
Nov 27 #Javascript
浅析Vue下的components模板使用及应用
Nov 27 #Javascript
d3.js 地铁轨道交通项目实战
Nov 27 #Javascript
微信小程序表单验证WxValidate的使用
Nov 27 #Javascript
vue(2.x,3.0)配置跨域代理
Nov 27 #Javascript
You might like
人族 TERRAN 概述
2020/03/14 星际争霸
ubuntu 编译安装php 5.3.3+memcache的方法
2010/08/05 PHP
PHP+Ajax+JS实现多图上传
2016/05/07 PHP
[原创]js获取数组任意个不重复的随机数组元素
2010/03/15 Javascript
前端开发必须知道的JS之原型和继承
2010/07/06 Javascript
javascript五图轮播切换实用版
2012/08/17 Javascript
Javascript中实现trim()函数的两种方法
2015/02/04 Javascript
javascript中JSON对象与JSON字符串相互转换实例
2015/07/11 Javascript
Javascript实现的Map集合工具类完整实例
2015/07/31 Javascript
JS中mouseover和mouseout多次触发问题如何解决
2016/06/06 Javascript
IE下JS保存图片的简单实例
2016/07/15 Javascript
Bootstrap图片轮播组件Carousel使用方法详解
2016/10/20 Javascript
教你用十行node.js代码读取docx的文本
2017/03/08 Javascript
纯js的右下角弹窗实例
2017/03/12 Javascript
微信小程序动态增加按钮组件
2018/09/14 Javascript
详解微信小程序网络请求接口封装实例
2019/05/02 Javascript
Python模块学习 datetime介绍
2012/08/27 Python
python中的装饰器详解
2015/04/13 Python
Python机器学习算法之k均值聚类(k-means)
2018/02/23 Python
使用Python3内置文档高效学习以及官方中文文档
2019/05/19 Python
flask框架单元测试原理与用法实例分析
2019/07/23 Python
jupyter notebook 实现matplotlib图动态刷新
2020/04/22 Python
Python爬虫教程知识点总结
2020/10/19 Python
北美领先的牛仔品牌:Buffalo David Bitton
2017/05/22 全球购物
递归计算如下递归函数的值(斐波拉契)
2012/02/04 面试题
采购员的工作职责
2013/12/26 职场文书
毕业生就业协议书
2014/04/11 职场文书
优秀教师感人事迹材料
2014/05/04 职场文书
岗位标兵事迹材料
2014/05/17 职场文书
工会主席事迹材料
2014/06/03 职场文书
公司大门门卫岗位职责
2014/06/11 职场文书
学校学雷锋活动总结
2014/06/26 职场文书
酒后驾车标语
2014/06/30 职场文书
美术教师个人总结
2015/02/06 职场文书
解析探秘fescar分布式事务实现原理
2022/02/28 Java/Android
如何Python使用re模块实现okenizer
2022/04/30 Python