最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

运算符&&的三个不同层次_基础知识

来源:懂视网 责编:小采 时间:2020-11-27 21:08:17
文档

运算符&&的三个不同层次_基础知识

运算符&&的三个不同层次_基础知识:运算符可以从三个不同的层次进行理解。 第一层理解 当操作数都是布尔值时,&&对两个值执行布尔与(AND)操作。 代码如下:x==0 && y==0 // 只有当x和y都是0时,才返回true 关系运算符的优先级比&&要高。 第二层理解 &&可以对真值和假值进行布尔
推荐度:
导读运算符&&的三个不同层次_基础知识:运算符可以从三个不同的层次进行理解。 第一层理解 当操作数都是布尔值时,&&对两个值执行布尔与(AND)操作。 代码如下:x==0 && y==0 // 只有当x和y都是0时,才返回true 关系运算符的优先级比&&要高。 第二层理解 &&可以对真值和假值进行布尔

运算符可以从三个不同的层次进行理解。

第一层理解

当操作数都是布尔值时,“&&”对两个值执行布尔与(AND)操作。

代码如下:
x==0 && y==0 // 只有当x和y都是0时,才返回true

关系运算符的优先级比”&&”要高。

第二层理解

”&&“可以对真值和假值进行布尔与(AND)操作。(假值有false、null、undefined、0、NaN和”“)。在JS中任何希望使用布尔值的地方,表达式和语句都会将其当做真值或假值来对待,因此实际上”&&”并不总是返回true和false。

代码如下:
null && true // =>null: 左操作数为假值,并将其返回,整个表达式为假
true && (5 - 3) // =>2: 左操作数为真,计算右操作数,并将其结果返回

第三层理解

当运算符要返回一个真值或假值时,根据左操作数的值会遇到两种运算情况:运算符首先计算左操作数的值,如果计算结果是假值,那么整个表达式的结果一定也是假值,此时”&&“简单的返回左操作数的值,而并不会对右操作数进行计算。如果左操作数是真值,”&&“将计算右操作数的值并将其返回作为整个表达式的计算结果。

代码如下:
var o = {x:1};
var p = null;
o && o.x; // =>1 o是真值,返回o.x的值
p && p.y; // =>null: p是假值,将其返回,而不去计算p.y

”&&“的行为有时称作”短路“,我们将会看到很多代码利用了这一特性进行有条件地执行代码。例如下面两行代码是完全等价的:

代码如下:
if(a == b) stop();
(a == b) && stop();// 与上面语句等价

知识延伸

运算符“||”和”&&”一样也具有一些复杂的行为。

用来从一组备选表达式中选出第一个真值表达式:

代码如下:
// 先检查a是否是真值,如果是,返回a,否则和a处理方式相同地处理b
// 如果b是真值返回b,否则返回5
var max = a || b || 5;

这种用法在函数中可以用来给参数提供默认值:

代码如下:
function copy(o, p) {
p = p || {}; // 如果没有向参数p传递对象,就使用新创建的对象
// ...
}

运算符优先级

同一优先级的运算符,运算次序由结合方向所决定。

简单记就是:! > 算术运算符 > 关系运算符 > && > || > 赋值运算符

文档

运算符&&的三个不同层次_基础知识

运算符&&的三个不同层次_基础知识:运算符可以从三个不同的层次进行理解。 第一层理解 当操作数都是布尔值时,&&对两个值执行布尔与(AND)操作。 代码如下:x==0 && y==0 // 只有当x和y都是0时,才返回true 关系运算符的优先级比&&要高。 第二层理解 &&可以对真值和假值进行布尔
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top