前言

!, &&, || 三个运算符是JavaScript中重要的逻辑运算符,本文将介绍这三个运算符在JavaScript实际编程中的有趣使用技巧。

取反运算符(!)

如果对一个值连续做两次取反运算,等于将其转为对应的布尔值,与Boolean函数的作用相同。

!!x
// 等同于Boolean(x)
复制代码

两次取反就是将一个值转为布尔值的简便写法。

var str='test';
var bl=!!str;
bl
// trueBoolean(str)
// true
复制代码

且运算符(&&)

且运算符的运算规则是:如果第一个运算子的布尔值为true,则返回第二个运算子的值(注意是值,不是布尔值);如果第一个运算子的布尔值为false,则直接返回第一个运算子的值,且不再对第二个运算子求值。

我们可以利用这个运算规则取代if结构,比如下面是一段if结构的代码,就可以用且运算符改写。

if (i) {doSomething();
}// 等价于i && doSomething();
复制代码

这种跳过第二个运算子的机制,被称为“短路”。

或运算符(||)

或运算符的运算规则是:如果第一个运算子的布尔值为true,则返回第一个运算子的值,且不再对第二个运算子求值;如果第一个运算子的布尔值为false,则返回第二个运算子的值。

var x = 1;
true || (x = 2) // true
x // 1
复制代码

短路规则对这个运算符也适用。

function saveText(text) {text = text || 'test';// ...
}// 或者写成
saveText(this.text || 'test')
复制代码

利用短路规则,或运算符可以为一个变量设置默认值。

转载于:https://juejin.im/post/5cfa13395188254628166a68

JavaScript逻辑运算符的使用技巧相关推荐

  1. JavaScript正则表达式快速判断技巧

    原文:JavaScript正则表达式快速判断技巧 这里是JS的正则的一点心得,并不是最完整的规则汇总,更侧重实际运用中的快速判断,初学者接触正则之后往往会被一堆星号括号给弄晕,有了一些速判技巧就能从整 ...

  2. JavaScript的方法和技巧

    摘自http://www.cnblogs.com/Jamedy/archive/2007/02/14/650079.html 有些时候你精通一门语言,但是会发现你其实整天在和其它语言打交道,也许你以为 ...

  3. JavaScript的一些实用技巧收藏

    JavaScript的一些实用技巧收藏 [Copy to clipboard] CODE: 1. οncοntextmenu="window.event.returnValue=false& ...

  4. 增强优化JavaScript性能的方法 - 技巧大全

    一.优化页面加载时间 在修改JavaScript代码提升网页或应用程序的性能之前,我们先了解一下客户端与JavaScript代码之间的交互处理: JavaScript代码通过HTML的<scri ...

  5. 12 个提高JavaScript编码效率的 NPM 技巧

    12 个提高JavaScript编码效率的 NPM 技巧 本文翻译自 blog.bitsrc.io/npm-tips-an- NPM,Node Package Manager,是 JavaScript ...

  6. [转]javascript常用的小技巧

    javascript常用的小技巧 分类: javascript 2011-12-19 09:30 170人阅读 评论(1) 收藏 举报 事件源对象 event.srcElement.tagName e ...

  7. 使用JavaScript的一些小技巧

    作者:Airen https://www.w3cplus.com/javascript/javascript-tips.html 任何一门技术在实际中都会有一些属于自己的小技巧.同样的,在使用Java ...

  8. JavaScript 调试建议和技巧

    浏览器开发者工具 我个人最喜欢Chrome开发者工具.虽然Safari和Firefox无法达到Chrome那么高的标准,但它们也在逐渐改善.在Firefox中,可以将Firebug和Firefox开发 ...

  9. javascript常用函数和技巧

    学习和工作的过程中总结的干货,包括常用函数.常用js技巧.常用正则表达式.git笔记等.为刚接触前端的童鞋们提供一个简单的查询的途径,也以此来缅怀我的前端学习之路. PS:此文档,我会持续更新. Aj ...

最新文章

  1. c语言中副作用和顺序点的理解
  2. 构造函数调用虚函数的问题
  3. vue按钮字体大小设置_vue-elementui之按钮
  4. 4:springApplication.run 原理
  5. 批量梯度下降 linux,梯度下降的三种形式BGD,SGD,MBGD(MSGD)
  6. 4、表单和高级选择器
  7. Travis CI上的sonar build错误
  8. 关于HTML的面试题-html4/css2篇
  9. LeetCode 1832. 判断句子是否为全字母句
  10. 云开发是啥?看看它在编程导航项目的实践
  11. 基于ObjectCache的应用
  12. Java速成:37-贷款计算器
  13. 前端VUE学习总结(一)
  14. 制作动态微信二维码名片python
  15. maya2020卸载不干净安装不了_Maya2020安装失败怎么办?2018却可以安装?
  16. 我们为什么不画高保真原型图
  17. py读取xlsx文件
  18. DNW的详细配置及使用过程
  19. android ndk之opencv+MediaCodec硬编解码来处理视频动态时间水印
  20. Git生成公钥及查看公钥

热门文章

  1. python函数拟合不规则曲线_python曲线拟合
  2. 为什么用python写爬虫_python-做爬虫,如何避免牢狱之灾
  3. 【NOIP模拟】图论题Graph
  4. 739. Daily Temperatures - LeetCode
  5. 查看Eclipse中的jar包的源代码:jd-gui.exe
  6. 开源组件DocX导出Word
  7. C# 与java区别总结 收集
  8. Js整理备忘(02)——运算符
  9. 表格过滤器_不用记账软件也可以记录支出明细,这个在线协同表格很方便
  10. 嵌入式软件工程师2021面试指南【转】