问题解决:
先来解决上篇博客邮寄地址出现0的问题
原因:可以看到null+null=0
邮寄地址拼接的省市县和详细地址,没有做判空处理,出现了null+null的情况。
var address = data.invoiceProvince+data.invoiceCity+data.invoiceCounty+data.invoiceDetailaddress;
这个问题解决了,但是下个问题又来了,为什么省市县的取值出现了null,什么情况下是null
同时结合我的某篇博客 Mysql中Null和空在Java和Js中的表现 来看。
js获取java数据为null和undefined情况:
mysql中的空白值和null
Mysql | Java | JS | 备注 |
空白值 | ‘’ | ‘’ | 不区分接收数据的类型,永远都存在对应的属性,只要sql查询了这个字段 |
Null | Map接受,map中没有对应字段的key-value | 从map获取对应的值为undefined |
|
实体对象接受,对应的属性值是null | 从实体对象获取具体为null还是undefined不确定?(疑惑1) |
| |
实体对象接收,但是中间经过map处理,map中仍然存在对应的属性值 | 从map的对象获取具体为null还是undefined不确定?(疑惑2) |
| |
sql语句不查询这个字段的时,采用实体对象接收,对应属性值不知道是否还存在 | 从实体对象获取具体为null还是undefined不确定?(疑惑3) | sql语句不查询这个字段,采用实体接收 |
java代码访问mysql数据库。
mysql中的默认的null值,在实体中返回时是以 null 返回的。在map中不存在这个字段。
这一步检验有时候会在java代码检验返回值是否为空时候用到。可能会报java.lang.NullPointerException
null和undefined比较:
第一种:出现
undefined表示"缺少值",就是此处应该有一个值,但是还没有定义。典型用法:
①对象没有赋值的属性,该属性的值为undefined。
②变量被声明了,但没有赋值时,就等于undefined。
③调用函数时,应该提供的参数没有提供,该参数等于undefined。
④函数没有返回值时,默认返回undefined。
第一种情况:在我们-s获取java数据为null和undefined情况,已经说明。
第二种情况:
第三种情况:
function f(x){console.log(x)}
f() // undefined
第四种情况:
var x = f();
x // undefined
第二种:转换为数字的时候
null是一个表示"无"的对象,转为数值时为0;null和任何数字相加(包括null)都等于0。
undefined是一个表示"无"的原始值,NaN(Nota Number)。undefiend和任何数字相加(包括undefined和null)都是NaN
区别总结:
①undefined是定义了但是没有赋值或者对象属性没有定义,null是赋值的时候就是没有值。
②undefiend和任何数字相加是NaN,null和任何数字相加是0;
下一篇博客:NaN的产生