`

JavaScript条件表达式的布尔判断

阅读更多
在JavaScript中,对于单独作为判断式里的一个表达式if(aaa)这样的条件判断时,会先把aaa转换成布尔型true或false,再判断其真假。其他类型转换布尔型的规则是:
对于只定义未赋值的变量var aaa,其值为undefined,为false.

字符串:空字符串""转换布尔型为false,其它为true;

数字:数字0转换为布尔值为false,其它为true;

对象:为null的对象转换为布尔型为false,其它为true;

对象属性值:未声明的属性值、属性值为0或空串""或false或null的,转换布尔值为false,其余为true;


对于用==号判断的条件表达式if(aaa==bbb)与if(aaa)的情况时,以下是几个容易出错的例子:
var a = "";
if(a==0){
	alert("空串==0为真");//打印
}
if(0==a){
	alert("0==空串为真");//打印
}
if(0){
	alert("0 true");
}else{
	alert("0 false");//打印
}
var v = 0;
if(v){
	alert("值为0的变量 true");
}else{
	alert("值为0的变量 false");//打印
}
if(v==false){
	alert("0==false为真");//打印
}
	
var obj = new Object();
obj.aa = 0;
obj.bb = false;
if(obj.aa){
	alert("对象属性值为0 true");
}else{
	alert("对象属性值为0 false");//打印
}
if(obj.bb){
	alert("对象属性值为false true");
}else{
	alert("对象属性值为false false");//打印
}
	
if(obj.aa==obj.bb){
	alert("震撼");//打印
}
if(obj.bb==0){
	alert("震撼++");//打印
}
if(obj.bb==""){
	alert("震撼++");//打印
}

要知道以下三个是为true的:
""==0
""==false
0==false
以下几个也是为true的,奇怪吧:
0=="      "
0=="   0  "
0=="       000000000       "

总结如下:
1.==和!=是比较运算符,但当类型不同时会进行类型转换,例如false==0这个条件为真;

2.而===和!==不会进行类型转换,类型不同就判断它们不同,所以false===0这个条件为假;

3.一般为了安全起见,都是使用===进行比较的;


运算符==读作相等,而运算符===则读作等同

相等运算符:
如果操作数具有相同的类型,则判断其等同性,如果两个操作数的值相等,则返回true(相等),否则返回false(不相等).

如果操作数的类型不同,则按照这样的情况来判断:

1.null和undefined相等

2.其中一个是数字,另一个是字符串,比较规则是:
    if该字符串是空字符串""或者是空格组成的字符串"     ",则先将该字符串转换为数字0,再做比较,例如:
         0==""为true   0=="      "也为true;
    else其他情况,则先将该字符串转换为数字,再做比较,例如12=="   12  "为true的;

3.一个是true,先转换成1(false则转换为0),再做比较

4.如果一个值是对象,另一个是数字/字符串,则将对象转换为原始值(通过valueOf()或者toString()方法,其中valueOf方法优先)

5.其他情况,则直接返回false

等同运算符:
如果操作数的类型不同,则不进行值的判断,直接返回false

如果操作数的类型相同,分下列情况来判断:

1.都是数字的情况,如果值相同,则两者等同(有一个例外,就是NaN,NaN与其本身也不相等),否则不等同

2.都是字符串的情况,与其他程序设计语言一样,如果串的值不等,则不等同,否则等同

3.都是布尔值,且值均为true/false,则等同,否则不等同

4.如果两个操作数引用同一个对象(数组,函数),则两者完全等同,否则不等同

5.如果两个操作数均为null/undefined,则等同,否则不等同

比如:
var obj = {   
    id : "self",   
    name : "object"  
};   
var oa = obj;   
var ob = obj;   
alert(oa == ob);  //true 
alert(oa === ob);  //true

再来看一个对象的例子:
var obj1 = {   
    id : "self",   
    name : "object",   
    toString : function(){   
       return "object 1";   
    }   
}   
var obj2 = "object 1";   
alert(obj1 == obj2);   //true
alert(obj1 === obj2);  //false
obj1是一个对象,而obj2是一个结构与之完全不同的字符串,而如果用相等操作符来判断,则两者是完全相同的,因为obj1重载了顶层对象的toString()方法。
而!=不等和!==不等同,则与==/!==相反。因此,在JavaScript中,使用相等/等同,不等/不等同的时候,一定要注意类型的转换,这里推荐使用等同/不等同来进行判断,这样可以避免一些难以调试的bug。
分享到:
评论
1 楼 fancyleeo 2012-06-28  
很好!这么好的文章没人顶?

相关推荐

    精通 JavaScript正则表达式

    正则表达式对象提供了几个方法,如 `test()`,它返回一个布尔值,表示字符串中是否存在匹配模式;`exec()` 返回一个包含匹配结果的数组;`compile()` 可以编译正则表达式以提高性能。 此外,还有一些只读属性,如 `...

    javascript正则表达式学习笔记

    1. `test()`:测试字符串是否匹配正则表达式,返回布尔值。 2. `exec()`:执行一个正则表达式并返回匹配结果,如果没有找到匹配项,则返回null。 3. `match()`:在字符串中搜索匹配正则表达式的子串,返回一个数组。...

    最新的javascript正则表达式详解

    JavaScript中的正则表达式是进行文本处理和数据验证的强大工具,它允许我们通过模式匹配来查找、替换或分割字符串。本文将深入探讨JavaScript正则表达式的最新特性、语法以及常见用法。 一、正则表达式基础 1.1 ...

    javaScript正则表达式讲解用ppt

    - `test`:测试字符串是否符合正则表达式模式,返回布尔值。 - `search`:返回第一个匹配项的开始位置,找不到返回-1。 - `split`:根据正则表达式分割字符串,返回一个数组。 - `match`:在字符串中查找匹配项...

    JavaScript正则表达式.rar

    - JavaScript 的正则表达式不支持一些高级特性,如条件表达式、递归和平衡组。 理解并熟练运用这些知识点,开发者可以在JavaScript中编写出高效的正则表达式,处理各种复杂的文本问题。文档`JavaScript使用正则...

    Javascript正则表达式校验共7页.pdf.zip

    7. **方法**:在JavaScript中,`test()`用于测试字符串是否符合正则表达式,返回布尔值;`match()`返回匹配结果数组;`exec()`在全局匹配时可以多次调用;`replace()`替换匹配的部分;`search()`查找第一个匹配项的...

    javaScript正则表达式帮助文档

    1. `test()`: 使用正则表达式测试字符串,返回布尔值。例如,`/abc/.test('abcd')`返回`true`。 2. `match()`: 在字符串中搜索匹配正则表达式的子串,返回一个数组。如果没有找到匹配项,返回`null`。 3. `search...

    javascript正则表达式详解

    **JavaScript正则表达式详解** 正则表达式(Regular Expression)是编程中用于处理文本的强大工具,尤其在JavaScript中,它的应用广泛且深入。本文将详细介绍JavaScript中的正则表达式,以及如何通过Jakarta-ORO ...

    JavaScript经典正则表达式实战

    JavaScript正则表达式是编程语言JavaScript中的一个重要组成部分,它用于处理文本字符串,进行模式匹配、查找、替换等操作。在JavaScript中,正则表达式是一种强大的工具,可以帮助开发者实现复杂的数据验证、文本...

    JavaScript手册及正则表达式详解[收藏]

    正则表达式则是JavaScript中的一个重要工具,用于处理字符串的模式匹配和查找。在这个“JavaScript手册及正则表达式详解”中,我们将深入探讨这两个关键主题。 一、JavaScript基础 JavaScript是一种解释型、弱类型...

    javascript正则表达式全攻略

    1. 使用 `lookahead` 和 `lookbehind` 进行条件匹配,但JavaScript不完全支持零宽断言。 2. 使用 `flags` 属性获取或设置正则表达式的标志。 3. `RegExp.prototype.source` 获取正则表达式的源字符串。 通过以上...

    javascript 正则表达式

    JavaScript正则表达式是编程语言JavaScript中的一个重要组成部分,它用于处理文本模式匹配和字符串操作。在JavaScript中,正则表达式是一种强大的工具,允许我们执行复杂的文本搜索、替换和分割任务。下面将详细介绍...

    JavaScript 正则表达式(笔记)

    2. 根据业务需求,使用JavaScript的内置方法对数据进行初步判断。 3. 利用表单的`onsubmit`事件,在用户尝试提交表单时进行验证。如果数据不符合规则,可以阻止表单的提交。 对于简单的验证,如检查字符串长度或...

    javascript正则表达式总结.docx

    JavaScript正则表达式是编程语言JavaScript中用于处理文本模式匹配的重要工具。正则表达式(Regular Expression)是一种模式,用于匹配字符串中的一段或多段文本。以下是对JavaScript正则表达式的一些关键知识点的...

    javascript正则表达式

    - **`test()`**:测试字符串是否符合正则表达式,返回布尔值。 - **`exec()`**:在字符串中执行匹配,并返回匹配结果数组,如果没有找到匹配,则返回`null`。 - **`match()`**:在字符串中查找符合正则表达式的...

    07JavaScript正则表达式总结.docx

    - **test()**:检查字符串是否匹配正则表达式,返回布尔值。例如,`reg.test(str)`。 - **exec()**:与test()类似,但返回匹配的结果数组,如果未找到匹配,则返回null。 4. **字符串与正则表达式相关的方法**: ...

Global site tag (gtag.js) - Google Analytics