当前位置: 首页 > 编程笔记 >

Javascript基础教程之比较null和undefined值

姬庆
2023-03-14
本文向大家介绍Javascript基础教程之比较null和undefined值,包括了Javascript基础教程之比较null和undefined值的使用技巧和注意事项,需要的朋友参考一下

JavaScript 中有两个特数值: undefined和null,在比较它们的时候需要留心。在读取未赋值的变量或试图读取对象没有的属性时得到的就是 undefined 值。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Learn4UndefinedAndNull</title>
</head>
<body>
<script>
var myData = {
name:"Luka",
weather:"sunny"
};
document.writeln("Prop: "+myData.doesntexits);
</script>
</body>
</html> 

输出结果:

Prop: undefined

Javascript 又定义了一个特殊值 null ,这个值与 undefined 略有不同。后者是在未定义值得情况下得到的值,而前者则用于表示已经赋了一个值但该值不是一个有效的 object、string、number 或 boolean 值(也就是说所定义的是一个无值[no value])。

下面代码先后使用 undefined 和 null 以展示其不同效果:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Learn4UndefinedAndNull</title>
</head>
<body>
<script>
var myData = {
name:"Luka"
};
//读取 weather 属性
document.writeln("Var: "+myData.weather+"<br />");
//判断对象是否具有 weather 这个属性
document.writeln("Prop: "+("weather" in myData)+"<br /><br />");
myData.weather = "sunny";
document.writeln("Var: "+myData.weather+"<br />");
document.writeln("Prop: "+("weather" in myData)+"<br /><br />");
myData.weather = null;
document.writeln("Var: "+myData.weather+"<br />");
document.writeln("Prop: "+("weather" in myData)+"<br /><br />");
</script>
</body>
</html> 

输出结果:

Var: undefined
Prop: false
Var: sunny
Prop: true
Var: null
Prop: true

1. 检查变量或属性是否为undefined 或 null

如果想检查某属性是否为 null 或 undefined(不管是哪一个),那么只要使用 if 语句和逻辑非运算符(!)即可。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Learn4UndefinedAndNull</title>
</head>
<body>
<script>
var myData = {
name:"Luka",
city:null
};
if(!myData.name){
document.writeln("name is null or undefined <br /><br />");
}else {
document.writeln("name is not null or undefined <br /><br />")
}
if(!myData.city){
document.writeln("city is null or undefined <br /><br />");
}else {
document.writeln("city is not null or undefined <br /><br />")
}
if(!myData.weather){
document.writeln("weather is null or undefined <br /><br />");
}else {
document.writeln("weather is not null or undefined <br /><br />")
}
</script>
</body>
</html> 

输出结果:

name is not null or undefined
city is null or undefined
weather is null or undefined

2. 区分 null 和 undefined

在比较两个值时,所用办法应视需要而定。如果想同等对待 undefined值和null值,那么应该使用相等运算符(==),让 Javascript 进行类型转换。此时值为 undefined 的变量会被认为与值为 null 的变量相等。如果要区分 null 和 undefined,则应使用等同运算符(===)。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Learn4UndefinedAndNull</title>
</head>
<body>
<script>
var firstVal = null;
var secondVal;
var equality = firstVal == secondVal;
var identity = firstVal === secondVal;
document.writeln("Equality: "+equality+" <br />");
document.writeln("Identity: "+identity+" <br />");
</script>
</body>
</html> 

输出结果:

Equality: true
Identity: false

以上内容是小编给大家介绍的js基础教程之比较null和undefined值的相关知识,希望对大家有所帮助!

 类似资料:
  • 本文向大家介绍Javascript基础教程之比较操作符,包括了Javascript基础教程之比较操作符的使用技巧和注意事项,需要的朋友参考一下 和其他语言一样,JavaScript也有条件语句对流程上进行判断。包括各种操作符合逻辑语句 比较操作符 常用的比较操作符有      等于 == ,  不等于!= , 大于 >, 小于 <,大于等于 >= ,小于等于 <= 以上就是关于javascript

  • 本文向大家介绍Javascript基础教程之JavaScript语法,包括了Javascript基础教程之JavaScript语法的使用技巧和注意事项,需要的朋友参考一下 1.区分大小写 javascript中,变量、函数、运算符都区分大小写。 2.弱类型变量 定义变量只用 "var"关键字 3.每行结尾的分号可有可无。 4.括号用于代码块。 代码示例 第一篇文章就先这些吧,后续我们再详细介绍

  • 本文向大家介绍Javascript基础教程之变量,包括了Javascript基础教程之变量的使用技巧和注意事项,需要的朋友参考一下 javascript 中变量通过var关键字(variable)来声明的。 也可以通过var 关键字给变量多个值。 此外,与java不同,javascript可以在同一个变量中存储不同的数据类型。例如 另外,javascript不需要声明变量就可以使用,例如: jav

  • 本文向大家介绍Javascript基础教程之数组 array,包括了Javascript基础教程之数组 array的使用技巧和注意事项,需要的朋友参考一下 字符串,数值,布尔值都属于离散值(scalar),如果某个变量是离散的,那么任何时候它只有一个值。 如果想使用变量存储一组值,就需要使用数组(array)。 数组是由多个名称相同的树值构成的集合,集合中每个数组都是数组的元素(element),

  • 本文向大家介绍Javascript基础教程之函数对象和属性,包括了Javascript基础教程之函数对象和属性的使用技巧和注意事项,需要的朋友参考一下 包含在对象里的数据可以通过两种方式来访问 既属性的对象(property)和方法(method) 属性是隶属于某个特定对象的变量,方法则是某个特定对象才能调运的函数。 对象是由一些彼此相关的属性和方法集合在一起的一个数据实体、javacript中,

  • 本文向大家介绍Javascript基础教程之if条件语句,包括了Javascript基础教程之if条件语句的使用技巧和注意事项,需要的朋友参考一下 if 是常用语法之一,其格式如下 if(coditon) statement1 (else statement2) 其中,coditon可以是任何表达式,甚至不比是真正的布尔值,因为JavaScript会将其自动转化为布尔值。 如果条件执行结果为tru

  • 本文向大家介绍Javascript基础教程之数据类型 (数值 Number),包括了Javascript基础教程之数据类型 (数值 Number)的使用技巧和注意事项,需要的朋友参考一下 javascript中想限定一个数的数值,无需限定它是整数还是浮点数型 toExponential()函数是将数值转换为科学技术的方式显示,例如: 转下w3cschool数值的的对象属性和对象方法 Number

  • 本文向大家介绍Javascript基础教程之数据类型转换,包括了Javascript基础教程之数据类型转换的使用技巧和注意事项,需要的朋友参考一下 所有语言都有类型转化的能力,javascript也不例外,它也为开发者提供了大量的类型转化访法,通过全局函数,可以实现更为复杂的数据类型。  最简单的类型转化的例子 对于数据类型转为字符串,使用toString() JavaScript转化为字符串同时