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 相关文章推荐
拖动table标题实现改变td的大小(css+js代码)
Apr 16 Javascript
10分钟学会写Jquery插件实例教程
Sep 06 Javascript
Javascript的闭包详解
Dec 26 Javascript
node-webkit打包成exe文件被360误报木马的解决方法
Mar 11 Javascript
jQuery实现hover合成事件的方法
Aug 06 Javascript
JS实现的表格行鼠标点击高亮效果代码
Nov 27 Javascript
很全面的JavaScript常用功能汇总集合
Jan 22 Javascript
jQuery实现表格行和列的动态添加与删除方法【测试可用】
Aug 01 Javascript
整理一下常见的IE错误
Nov 18 Javascript
JS数组返回去重后数据的方法解析
Jan 03 Javascript
vue里面v-bind和Props 利用props绑定动态数据的方法
Aug 27 Javascript
基于elementUI实现图片预览组件的示例代码
Mar 31 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
在同一窗体中使用PHP来处理多个提交任务
2006/10/09 PHP
php开启openssl的方法
2014/05/15 PHP
PHPCMS2008广告模板SQL注入漏洞修复
2016/10/11 PHP
php 生成加密公钥加密私钥实例详解
2017/06/16 PHP
PHP中quotemeta()函数的用法讲解
2019/04/04 PHP
javascript css float属性的特殊写法
2008/11/13 Javascript
jquery.blockUI.js上传滚动等待效果实现思路及代码
2013/03/18 Javascript
JS 屏蔽键盘不可用与鼠标右键不可用的方法
2013/11/18 Javascript
简体中文转换繁体中文(实现代码)
2013/12/25 Javascript
JS输出空格的简单实现方法
2016/09/08 Javascript
Angular2 之 路由与导航详细介绍
2017/05/26 Javascript
webpack@v4升级踩坑(小结)
2018/10/08 Javascript
详解js创建对象的几种方法及继承
2019/04/12 Javascript
一个超级简单的python web程序
2014/09/11 Python
Python 序列化 pickle/cPickle模块使用介绍
2014/11/30 Python
利用nohup来开启python文件的方法
2019/01/14 Python
python for和else语句趣谈
2019/07/02 Python
python 3.74 运行import numpy as np 报错lib\site-packages\numpy\__init__.py
2019/10/06 Python
Python3将jpg转为pdf文件的方法示例
2019/12/13 Python
Python importlib动态导入模块实现代码
2020/04/16 Python
Python3实现飞机大战游戏
2020/04/24 Python
Python实现自动签到脚本的示例代码
2020/08/19 Python
python3.9和pycharm的安装教程并创建简单项目的步骤
2021/02/03 Python
英国拳击装备购物网站:RDX Sports
2018/01/23 全球购物
《夕阳真美》教学反思
2014/04/27 职场文书
奥巴马的演讲稿
2014/05/15 职场文书
2014年端午节演讲稿范文
2014/05/23 职场文书
假期安全教育广播稿
2014/10/04 职场文书
建筑工地文明标语
2014/10/09 职场文书
英语辞职信范文
2015/02/28 职场文书
小学重阳节活动总结
2015/03/24 职场文书
七年级作文之关于奶奶
2019/10/29 职场文书
教你利用Selenium+python自动化来解决pip使用异常
2021/05/20 Python
pytorch 梯度NAN异常值的解决方案
2021/06/05 Python
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/06 其他游戏
Win11更新失败并提示0xc1900101
2022/04/19 数码科技