-
布尔类型数据定义:
var valid= true;
var fail=false;
true/false 区分大小写,全小写有效。
- 其它类型值转换为boolean型值:
触发转换方式:
1.if(变量) 当变量为非boolean型值时,将其转换为boolean值再判断
2.使用 Boolean(变量) 将变量转换为boolean类型
转换规则:
数据类型 | 转为true值 | 转为false值 |
Boolean | true | false |
String | 任何非空字串 | “” |
Number | 任何非0数值 | 0 和NaN |
Object | 任何对象 | null |
Undefined | undefined |
注意(new Boolean(变量) 方式是创建Boolean对象,结果是对象,用if(Boolean对象)判断时,结果必然为true,因为该对象不为null)
-
!操作符
逻辑非可以应用任何类型的操作数,结果都会返回一个布尔类型。
格式: !操作数
alert(!true); // false
alert(!false); // true
如果操作数不是布尔型,首先会转换布尔型(转换规则如上),然后再对其求反。
- 如果操作数是对象,则返回false
- 如果操作数是空字符串,则返回true
- 如果操作数是非空字符串,则返回false
- 如果操作数是0,则返回true
- 如果操作数是非0,则返回false
- 如果操作数是null,则返回true
- 如果操作数是NaN,则返回true
- 如果操作数是undefined,则返回true
-
&&操作符
格式: 操作数1 && 操作数2
alert(true&&true); // true
alert(false&&false); // false
alert(false&&true); // false
alert(true&&false); // false
逻辑与操作符应用布尔值操作数时,规则为:两个操作数同时为true,则返回true,否则返回false.
逻辑与是短路操作符,如果第一个结果为false,就不会对二个表达式求值,而直接返回false;
逻辑与操作符还可以应用其它类型的操作数,其规则如下:
- 如果第一个操作数是对象,则返回第二个操作数
- 如果第二个操作数是对象,则在第一个操作数求值结果为true时,才返回第二个操作数
- 如果两个操作数都是对象,则返回第二个对象
- 如果第一个操作数是null,则返回null
- 如果第一个操作数是NaN,则返回NaN
- 如果第一个操作数是undefined ,则返回undefined.
简单说:第一个对象转换值为假,则返回第一个对象,否则返回第二个对象。
-
||操作符
格式: 操作数1 || 操作数2
alert(true||true); // true
alert(false|true); // true
alert(true|false); // true
alert(false|false); // false
逻辑或操作符应用布尔值操作数时,规则为:两个操作数同时为false,则返回false,否则返回true.
逻辑与是短路操作符,如果第一个结果为true,就不会对二个表达式求值,而直接返回true;
逻辑或操作符还可以应用其它类型的操作数,其规则如下:
- 如果第一个操作数是对象,则返回第一个操作数
- 如果第一个操作数是求值结果为false,则返回第二个操作数
- 如果两个操作数都是对象,则返回第一个对象
- 如果两个操作数是null,则返回null
- 如果两个操作数是NaN,则返回NaN
- 如果两个操作数是undefined ,则返回undefined.
简单说:第一个对象转换值为真,则返回第一个对象,否则返回第二个对象。
javascript逻辑运算符“||”和“&&”(转自:http://www.cnblogs.com/pigtail/archive/2012/03/09/2387486.html)
一、先来说说||(逻辑或),从字面上来说,只有前后都是false的时候才返回false,否则返回true。
alert(true||false); // true
alert(false||true); // true
alert(true||true); // true
alert(false||false); // false
但是,从深层意义上来说的话,却有另一番天地,试下面代码
alert(0||1);
显然,我们知道,前面0意味着false,而后面1意味着true,那么上面的结果应该是true,而事实返回的结果是1。再看下面代码:
alert(2||1);
我们知道,前面2是true,后面1也是true,那返回结果又是什么呢?测试结果是2,继续看:
alert('a'||1);
同样,前面'a'是true,后面1也是true;测试结果是'a',下面
alert(''||1);
由上,我们知道前面''是false,后面1是true,而返回结果是1。再看下面
alert('a'||0);
前面'a'是true,而后面0是false,返回结果是'a',继续下面
alert('a'||'b');
前面'a'是true,后面'b'是false,返回结果是'a',我们继续下面
alert(''||0);
前面''是false,后面0同样是false,返回结果是0
alert(0||'');
前面0是false,后面''是false,返回结果是''
这就意味
1、只要“||”前面为false,不管“||”后面是true还是false,都返回“||”后面的值。
2、只要“||”前面为true,不管“||”后面是true还是false,都返回“||”前面的值。
----------------------------------------------------------------------------------------------------------
二、下面说说&&(逻辑与),从字面上来说,只有前后都是true的时候才返回true,否则返回false。
alert(true&&false); // false
alert(true&&true); // true
alert(false&&false); // false
alert(false&&true); // false
然后,根据上面经验,我们看看“&&”号前后,不单单是布尔类型的情况。
alert(''&&1);
结是返回'',“&&”前面''是false,后面是1是true。
alert(''&&0);
结是返回'',“&&”前面''是false,后面是0也是false。
alert('a'&&1);
结是返回1,“&&”前面''a是true,后面是1也是true。
alert('a'&&0);
结是返回0,“&&”前面''a是true,后面是0是false。
alert('a'&&'');
结是返回'',“&&”前面''a是true,后面是''是false。
alert(0&&'a');
结是返回0,“&&”前面''0是false,后面是'a'是true。
alert(0&&'');
结是返回0,“&&”前面''0是false,后面是''也是false。
这意味着
1、只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值;
2、只要“&&”前面是true,无论“&&”后面是true还是false,结果都将返“&&”后面的值;
让我们总结一下:
1、只要“||”前面为false,无论“||”后面是true还是false,结果都返回“||”后面的值。
2、只要“||”前面为true,无论“||”后面是true还是false,结果都返回“||”前面的值。
3、只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值;
4、只要“&&”前面是true,无论“&&”后面是true还是false,结果都将返“&&”后面的值;
由上两个测试可知,逻辑运算符,“||”和“&&”都是遵行短路原则,只要确定符号前面的真假,既可确定返回值。
需要说明的是“&&”的优先级是高于“||”的,下面测试:
alert(1||'a'&&2);
返回结果是1。
根据反证原理,我们假设“||”的优先级不低于“&&”(这里只所以用“不低于”,是为了同时证明等级相同的情况)。
根据上面我们得出的结论(1),(1||'a')将返回前面的值1,(1&&2)根据结论(4)应该返回后面的值2。这显然不对,由此可知“&&”的优先级是高于“||”的。
相关推荐
在探讨Javascript布尔型分析的过程中,首先需要明确Javascript中的布尔型与Java中的布尔型虽然名称相同,但在实际使用中存在一些差异。特别是在类型转换的机制上,理解这些差异对于进行Java与Javascript交互的开发者...
4. **布尔型与其他类型转换**:布尔型可以与任何类型进行逻辑转换。非零数值被视为true,零和null被视为false,undefined也视为false。 5. **隐式转换**:JavaScript 在某些操作中会自动进行类型转换,例如在比较...
将这些值转换为布尔型通常会得到false。除了假值之外的其他值在转换为布尔值时都是真值(truthy value)。例如: ```javascript console.log(Boolean('')); // false console.log(Boolean(0)); // false ``` 在...
在JavaScript中,布尔型是预定义的JavaScript数据类型之一,其作用十分广泛。比如在条件语句、循环语句以及函数返回值等地方都有使用。JavaScript中的布尔值可用于控制流程,如使用if语句来决定程序的执行方向。 ...
JavaScript(简称JS)是一种轻量级、解释型、动态类型的脚本语言,主要用于网页前端开发,但也被广泛用于服务器端和移动应用开发。它最初由Netscape公司的Brendan Eich在1995年为Netscape Navigator浏览器设计,目的...
- **Boolean**:布尔型,只有两个值:true和false。 - **Number**:包含整数和浮点数。JavaScript中没有整型,所有数字都是Number类型。 - **String**:字符串,由单引号或双引号包围的字符序列。 - **Symbol**...
- **数值类型**:JavaScript不区分整型和浮点型,所有数值都是以浮点型存储。 - **字符串类型**:可以使用单引号或双引号包裹字符串。 - **布尔类型**:只有`true`和`false`两个值,全部小写。 - **数组类型**:...
标题 "类型级别的自然数布尔值和向量大小" 指涉的是编程语言中的一个高级特性,特别是与静态类型语言相关的。在这个主题中,我们主要关注三个方面:类型级别的自然数、布尔值以及向量(数组)大小。这些概念在...
JavaScript基础语法资料 ...19-布尔型Boolean.html 20-获取变量数据类型.html 21-字面量.html 22-转换为字符型.html 23-转换为数字型.html 24-计算年龄案例.html 25-简单加法器案例.html 26-转换为布尔型.html my.js
基本类型包括字符串(String)、数字(Number)、布尔值(Boolean)、空值(Null)、未定义(Undefined)和Symbol(ES6新增)。例如,`016-javascript-数据类型.html`可能详细解释了这些数据类型的特点、创建方式...
在 JavaScript 中,数据类型包括字符串(string)、数值型(number)、布尔型(boolean)、null、undefined 和对象(object)。其中数组(array)属于对象,判断数据类型需要使用 typeof() 函数。 变量 变量的命名...
JavaScript提供了几种方式来转换数据类型,如`Number()`、`parseInt()`和`parseFloat()`用于字符串到数字的转换,`String()`用于转换成字符串,以及`Boolean()`用于转换成布尔值。 学习JavaScript的数据类型是前端...
基本数据类型包括整型、浮点型、字符型、布尔型。对象类型包括内置对象(String、Math、Date)、浏览器对象(Window、Document、History、Forms、….)、用户自定义对象。 4. 变量 变量的命名规则与JAVA语言相同。...
1. JavaScript的变量类型:JavaScript中主要有几种基本的变量类型,包括字符串、整型、浮点型、布尔型、数组、对象、JSON对象、NaN、null和undefined。这些类型帮助我们定义和操作数据。 - 字符串类型用于表示文本...
它的核心特性包括变量、数据类型(如字符串、数字、布尔值、对象、null和undefined)、操作符、流程控制(如条件语句、循环)、函数以及对象和数组。其中,函数不仅是可执行的代码块,还可以作为值传递,体现了...
在这份"JavaScript程序设计课件:数据类型转换"中,主要讲解了如何在JavaScript中进行数据类型的转换,主要包括获取数据类型的方法以及三种主要的数据类型转换:字符串转换、数字转换和布尔型转换。 首先,了解数据...
JavaScript是一种广泛应用于网页和网络应用的轻量级、解释型编程语言,主要设计用于客户端的脚本语言。它由Netscape公司的LiveScript发展而来,最初由Brendan Eich在1995年发明,并在Netscape Navigator 2.0中引入,...