JS中或者(或 or ||)与并且(与 and )
一、||(逻辑或)
从字面上来说,只有前后都是false的时候才返回false,否则返回true。
alert(true||false); // true
alert(false||true); // true
alert(true||true); // true
alert(false||false); // false
但是,从深层意义上来说的话,却有另一番天地,试下面代码
alert(0||1);//1
显然,我们知道,前面0意味着false,而后面1意味着true,那么上面的结果应该是true,而事实返回的结果是1。再看下面代码:
alert(2||1);//2
我们知道,前面2是true,后面1也是true,那返回结果又是什么呢?测试结果是2,继续看:
alert('a'||1);//'a'
同样,前面’a’是true,后面1也是true;测试结果是’a’,下面
alert(''||1);//1
由上,我们知道前面”是false,后面1是true,而返回结果是1。再看下面
alert('a'||0);//'a'
前面’a’是true,而后面0是false,返回结果是’a’,继续下面
alert(''||0);//0
前面”是false,后面0同样是false,返回结果是0
alert(0||'');//''
前面0是false,后面”是false,返回结果是”
这就意味
1、只要“||”前面为false,不管“||”后面是true还是false,都返回“||”后面的值。
2、只要“||”前面为true,不管“||”后面是true还是false,都返回“||”前面的值。
我称这种为短路原理: 知道了前面第一个的结果就知道后的输出,如果为第一个为:true,则取第一个的值,如果第一个为false,则取第二个的值。
js必须牢记的6个蛋蛋: 请你一定要记住:在js逻辑运算中,0、”“、null、false、undefined、NaN都会判为false,其他都为true(好像没有遗漏了吧,请各位确认下)。这个一定要记住,不然应用||和&&就会出现问题。
这里顺便提下:经常有人问我,看到很多代码if(!!attr),为什么不直接写if(attr);
其实这是一种更严谨的写法:
请测试 typeof 5和typeof !!5的区别。!!的作用是把一个其他类型的变量转成的bool类型。
二、&&(逻辑与)
从字面上来说,只有前后都是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
结是返回1,“&&”前面”a是true,后面是1也是true。
alert('a'&&0);//0
结是返回0,“&&”前面”a是true,后面是0是false。
alert('a'&&'');//''
结是返回”,“&&”前面”a是true,后面是”是false。
alert(0&&'a');//0
结是返回0,“&&”前面”0是false,后面是’a’是true。
alert(0&&''); //0
结是返回0,“&&”前面”0是false,后面是”也是false。
短路原理
1、只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值;
2、只要“&&”前面是true,无论“&&”后面是true还是false,结果都将返“&&”后面的值;
3.在开发中的应用
下面三段代码等价:
a=a||"defaultValue";
if(!a){
a="defaultValue";
}
if(a==null||a==""||a==undefined){
a="defaultValue";
}
你愿意用哪一个呢?
2、 像var Yahoo = Yahoo || {};这种是非常广泛应用的。 获得初值的方式是不是很优雅?比if。。。。else…好很多,比?:也好不少。
3、 callback&&callback()
在回调中,经常这么写,更严谨,先判断 callback 是不是存在,如果存在就执行,这样写的目的是为了防止报错
如果直接写 callback(); 当callback不存在时代码就会报错。
4、综合实例
需求如图:
这里写图片描述
假设对成长速度显示规定如下:
成长速度为5显示1个箭头;
成长速度为10显示2个箭头;
成长速度为12显示3个箭头;
成长速度为15显示4个箭头;
其他都显示都显示0各箭头。
用代码怎么实现?
差一点的if,else:
var add_level = 0;
if(add_step == 5){
add_level = 1;
}
else if(add_step == 10){
add_level = 2;
}
else if(add_step == 12){
add_level = 3;
}
else if(add_step == 15){
add_level = 4;
}
else {
add_level = 0;
}
稍好些的switch:
var add_level = 0;
switch(add_step){
case 5 : add_level = 1;
break;
case 10 : add_level = 2;
break;
case 12 : add_level = 3;
break;
case 15 : add_level = 4;
break;
default : add_level = 0;
break;
}
如果需求改成:
成长速度为>12显示4个箭头;
成长速度为>10显示3个箭头;
成长速度为>5显示2个箭头;
成长速度为>0显示1个箭头;
成长速度为<=0显示0个箭头。
那么用switch实现起来也很麻烦了。
那么你有没有想过用一行就代码实现呢?
ok,让我们来看看js强大的表现力吧:
var add_level = (add_step==5 && 1) || (add_step==10 && 2) || (add_step==12 && 3) || (add_step==15 && 4) || 0;
更强大的,也更优的:
var add_level={'5':1,'10':2,'12':3,'15':4}[add_step] || 0;
第二个需求:
var add_level = (add_step>12 && 4) || (add_step>10 && 3) || (add_step>5 && 2) || (add_step>0 && 1) || 0;
原文链接:https://blog.csdn.net/shenenhua/article/details/79071965
JS中或者(或 or ||)与并且(与 and )相关推荐
- 在js中使用HashMap数据结构,在js中使用K,V数据结构
首先是定义一个HashMap方法,做基类(复制在js中即可,然后引用) //简单的哈希表,begin function HashMap() {/** Map 大小 * */var size = 0;/ ...
- [JavaScript] 探索JS中的函数秘密
函数长啥样? 把一些要重复使用的内容封装到函数内. function foo(title) {console.log(title) } foo('title') foo('dust') foo('he ...
- 在node.js中,使用基于ORM架构的Sequelize,操作mysql数据库之增删改查
Sequelize是一个基于promise的关系型数据库ORM框架,这个库完全采用JavaScript开发并且能够用在Node.JS环境中,易于使用,支持多SQL方言(dialect),.它当前支持M ...
- 在JS中最常看到切最容易迷惑的语法(转)
发现一篇JS中比较容易迷惑的语法的解释,挺有用的,转载下,与大家分享: js中大括号有四种语义作用 语义1,组织复合语句,这是最常见的 Js代码 if( condition ) { //... }e ...
- js去el的map_转:el表达式获取map对象的内容 js中使用el表达式 js 中使用jstl 实现 session.removeattribute...
原文链接: 总结: el表达式获取map对象的内容 后端: HashMap map1 = new HashMap(); map1.put("key1","lzsb&quo ...
- js中substr,substring,indexOf,lastIndexOf的用法
js中substr,substring,indexOf,lastIndexOf等的用法 1.substr substr(start,length)表示从start位置开始,截取length长度的字符串 ...
- js中的各种宽高以及位置总结
在javascript中操作dom节点让其运动的时候,常常会涉及到各种宽高以及位置坐标等概念,如果不能很好地理解这些属性所代表的意义,就不能理解js的运动原理,同时,由于这些属性概念较多,加上浏览器之 ...
- WKWebView Safari调试、JS互调、加载进度条、JS中alert、confirm、prompt
主要内容 Safari调试 swift/OC与JS互调 增加加载进度条 支持JS中alert.confirm.prompt Safari调试 设置 -> safari --> 高级,开启J ...
- 彻底理解js中this
相关博文:http://blog.csdn.net/libin_1/article/details/49996815 彻底理解js中this的指向,不必硬背. 首先必须要说的是,this的指向在函数定 ...
- 彻底理解js中this的指向
首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然 ...
最新文章
- 《iOS应用开发指南——使用HTML5、CSS3和JavaScript》——导读
- ETL数据处理后的业务分析(一)
- Asp程序做页面的301跳转,使得cnasda.com跳转到www.cnasda.com
- 根据自己的博客数据统计国内IT人群
- python爬虫天气实例scrapy_2017.08.04 Python网络爬虫之Scrapy爬虫实战二 天气预报...
- 自动驾驶_基于强化学习的自动驾驶系统
- java list indexof_Java LinkedList indexOf()方法
- 计算机二级vfp考试怎么学,计算机二级VFP考试基础教程(7)
- 2022-07-12
- 原材料涨价引发全LED显示屏全产业链价格上浮!
- 12306网站火车票抢票详细攻略(gohome抢票程序)
- 数据库学习纪要(十二):SQL Sever介绍-4
- 每天自学3~4小时java,一年后能到什么程度
- FL Studio第 24 个年头:Image-Line 升级 FL Studio 21 音乐工作站
- 高通驱动开发参考(二)
- OA系统如何实现实时项目成本核算
- html5工业相机,AVT工业相机
- Python日常小技巧(持续更新中)
- 一台电脑同时上内网和外网
- C++友元和运算符重载
热门文章
- Linux环境Font font = new Font() 中文乱码 (带字体资源)
- mysql日志分析工具之mysqlsla
- CV基础(图像预处理)
- 华为鸿蒙主题曲,【AVW分享】华为云《鲲鹏》主题曲,华为宣传片MV剪辑版,超级带感的音乐...
- 解决ublox无法定位问题(一直输出$GxTXT)
- 星起航:短视频内容的流量迸发让电商渠道看到了新的趋势
- bootstrap 表单验证
- 微信端视频播放防被浏览器劫持
- template 的 用法
- 【mysql进阶-彩蛋篇】深入理解顺序io和随机io(全网最详细篇)