在JavaScript中,对于 if else 的逻辑判断你肯定非常熟悉,本文罗列了几种你不一定知道的简写方式,仅供参考。

例子:

已知小明考了68分,小于60分为不及格,大于60分为及格,问:小明是否通过了考试?

1.传统的写法

if(score < 60){
alert('不及格');
}else{
alert('及格');
}

这没什么好说的,最基本的if else语法。可读性应该是最好的。

2.利用三目运算符来进行判断

score < 60 ? alert('不及格') : alert('及格') ;

这种写法应该还算是比较多见的,而且,如果只有单纯的一个if判断的话,可读性也不是很差。

3.利用&& 来判断

score < 60 && alert('不及格') ;
score >= 60 && alert('及格') ;

**&&的用法 **: 如果左边的结果为真,那么运行右边的表达式,如果右边的也为真,那么就返回真。其中,只要有一个为假,结果就是假。并且,一旦左边的结果为假,右边的就不执行了。

这里就是取了一个巧,因为我只是想要执行右边的表达式,无所谓返回值是什么。

那么,如果score < 60 为真,我不管三七二十一,都去执行一下右边的代码。我们的目的已经达到了。

这不就相当于这样吗:

if(score < 60 == true){
alert('不及格') ;
} if(score >= 60 == true){
alert('及格') ;
}

简写:

if(score < 60){
alert('不及格') ;
} if(score >= 60){
alert('及格') ;
}

就是说,一旦 ( ) 里面的表达式为真,就执行 { } 里面的内容。否则就不执行。

4.利用 || 来判断

score < 60  ||  alert('及格') ;
score >= 60 || alert('不及格') ;

**|| 的用法 **: 如果左边的结果为真,那么直接返回true,右边的就忽略了!

如果左边为假,那么就运行右边的,看看右边的结果如何?如果右边为真,就返回真,否则返回假。

也就是说,不管右边的结果怎样,只要左边为假了,右边就无论如何会被执行一次的。这边也就是利用这个原理,相当于这样:

if(score < 60 == false){
alert('及格') ;
} if(score >= 60 == false){
alert('不及格') ;
}

如果分数 < 60 是假的,是骗你的,不就是说分数 > 60 才是真相吗?哦,超过60分就是及格了,所以alert出来的是及格。

如果分数 >= 60 是假的,是骗你的,不就是说分数 < 60 才是真相吗?哦,不满60分就是不及格了,所以alert出来的是不及格。

这样应该说的比较清楚了吧。

再说得白一点,就是:

你要么给我 < 60 ,要么给我 alert('及格') ;

你要么给我 >= 60 ,要么给我 alert('不及格') ;

5.实战演练

我们来一个小案例,看看可以怎么运用这些知识点?

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<style type="text/css">
.box1 {
height:200px;
width:300px;
border: 1px solid #666;
} .box2 {
background: green;
} </style>
<script> </script>
</head>
<body>
<div id='myBox' class='box1'></div>
</body>
</html>

我们引入了jQuery,现在希望自己来编写一个toggelClass,如何实现呢?

当我们点击这个div的时候,就自动将class换成box2。再次点击的时候,就把box2的样式去掉,依此循环。

上代码:

$('document').ready(function(){
function toggleClass(dom , className){
//判断该class是否已经存在
if(dom.hasClass(className)){
//如果存在,就去掉这个class
dom.removeClass(className);
}else{
//如果不存在,就加上这个class
dom.addClass(className);
}
} $('#myBox').click(function(){
toggleClass($(this),'box2');
});
});

我猜想,jQuery对toggleClass的实现应该也差不多是这个意思。现在,我们考虑做如下简化:

第一种方式,用三目运算符简化:

function toggleClass(dom , className){
dom.hasClass(className) ? dom.removeClass(className) : dom.addClass(className);
}

第二种方式,用&& 和 ||:

!dom.hasClass(className) && dom.addClass(className) || dom.removeClass(className);

可能有点绕,而且我也不是很推荐这种方式,一般来说,这种方式用于一些给变量赋值的场合。

我大概解释一下:

!dom.hasClass(className) && dom.addClass(className)

这表示如果dom元素不包含你指定的className,那么 !dom.hasClass(className) 是真,于是无论如何我都要执行右边的代码: dom.addClass(className) ,也就是说,给dom元素添加这个class。

这样一来,

!dom.hasClass(className) && dom.addClass(className)

这句话是不是已经成立了,OK,那么因为右边是 || , 左边都已经成立了,那么我右边的代码是不是可以不执行了呀?

好的,第二次点击:

!dom.hasClass(className)的意思是说,你这个dom元素是不是没有指定的class啊,不,我们刚才已经添加了,所以是有的。

那么,这句话就不成立了,&& 左边的是假,那么右边的就不执行了、

就是说:

 dom.addClass(className)

这句话不执行了。

综合来看:

!dom.hasClass(className) && dom.addClass(className)

这个条件就是不成立的。

好的, || 左边的不成立,是不是说,我们无论如何都要执行一下||右边的代码呢?

恩, dom.removeClass(className) 就被执行了。

本章结束 ...

剽悍一小兔,电气自动化毕业。

参加工作后对计算机感兴趣,深知初学编程之艰辛。

希望将自己所学记录下来,给初学者一点帮助。

我的个人博客:http://s-335245.gotocdn.com:8080/index.html

简书地址:http://www.jianshu.com/users/8875b36caaec/latest_articles

免责声明: 博客中所有的图片素材均来自百度搜索,仅供学习交流,如有问题请联系我,侵立删,谢谢。

你可曾见过如此简单粗暴的JavaScript解说 -- if 判断的正确打开方式?的更多相关文章

  1. 简单粗暴的JavaScript笔记-1

    欢迎到我的简书查看我的文集 前言: 提示密码提示框 <head> <style> #div1 {width: 100px;height:50px;background:#FFC ...

  2. 简单粗暴的对android so文件加壳,防止静态分析

    转载自http://bbs.pediy.com/showthread.php?t=191649 以前一直对.so文件加载时解密不懂,不了解其工作原理和实现思路.最近翻看各种资料,有了一些思路.看到论坛 ...

  3. 简单粗暴地理解js原型链--js面向对象编程

    原型链理解起来有点绕了,网上资料也是很多,每次晚上睡不着的时候总喜欢在网上找点原型链和闭包的文章看,效果极好. 不要纠结于那一堆术语了,那除了让你脑筋拧成麻花,真的不能帮你什么.简单粗暴点看原型链吧, ...

  4. 制作自己的MVC框架(一)——简单粗暴的实现

    现在市面上有很多成熟的MVC框架,可以拿来直接用,但自己造一下轮子其实也挺有意思的. 下面先来看个最简单粗暴的MVC实现. 5个文件就能实现最简单的MVC,在Apache中设置一个虚拟目录,配置个简单 ...

  5. 足球游戏论坛数据分析--简单粗暴的K均值聚类

    在<<足球游戏论坛数据分析--简单粗暴的贝叶斯>>中尝试了贴标签后,一直觉得结果无法接受, 慢慢回想, 其实选择的算法是错误的,原因有 论坛帖子分类并非就是PC/PS/XBOX ...

  6. 简单粗暴地理解 JavaScript 原型链 (一个充满歪门邪理的理解方法,有助于新手哦!)

    原型链理解起来有点绕了,网上资料也是很多,每次晚上睡不着的时候总喜欢在网上找点原型链和闭包的文章看,效果极好. 不要纠结于那一堆术语了,那除了让你脑筋拧成麻花,真的不能帮你什么.简单粗暴点看原型链吧, ...

  7. 好文要顶之 --- 简单粗暴地理解 JavaScript 原型链

    原型链理解起来有点绕了,网上资料也是很多,每次晚上睡不着的时候总喜欢在网上找点原型链和闭包的文章看,效果极好. 不要纠结于那一堆术语了,那除了让你脑筋拧成麻花,真的不能帮你什么.简单粗暴点看原型链吧, ...

  8. jsp+urlrewrite实现html分页简单粗暴实现

    今天去检查一同事写的一分页实现,看了有点郁闷,都说了要换成html实现方便搜索引擎收录,他还是用的js,真是晕.还得帮他解决 好吧.言归正传,我在他的基础上粗暴的修改了下,达到了基本的效果,带数字分页 ...

  9. 简单粗暴的在vmware虚拟机中固定ip

    虚拟机对于很多做测试的或者在学习测试中的人来说是位常客,经常会用到,但是虚拟机重启之后,很多人遇到虚拟机ip变化,很是头痛,我在学习过程中也遇到了这个问题,百度了很多办法,有些办法对于网络知识小白来说 ...

随机推荐

  1. Entity Framework Core 实现MySQL 的TimeStamp/RowVersion 并发控制

    将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库中的实现.SQ ...

  2. Hyper-V无法文件拖拽解决方案~~~这次用一个取巧的方法架设一个FTP来访问某个磁盘,并方便的读写文件

    异常处理汇总-服 务 器 http://www.cnblogs.com/dunitian/p/4522983.html 服务器相关的知识点:http://www.cnblogs.com/dunitia ...

  3. C# 多种方式发送邮件(附帮助类)

    因项目业务需要,需要做一个发送邮件功能,查了下资料,整了整,汇总如下,亲测可用- QQ邮箱发送邮件 #region 发送邮箱 try { MailMessage mail = new MailMess ...

  4. 【初学python】使用python调用monkey测试

    目前公司主要开发安卓平台的APP,平时测试经常需要使用monkey测试,所以尝试了下用python调用monkey,代码如下: import os apk = {'j': 'com.***.test1 ...

  5. ASP.NET MVC5+EF6+EasyUI 后台管理系统(64)-WebApi与Unity注入

    系列目录 前言: 有时候我们系统需要开放数据给手机App端或其他移动设备,不得不说Asp.net WebApi是目前首选 本节记录Asp.net MVC WebApi怎么利用Unity注入.系列开头已 ...

  6. EntityFramework Core 1.1是如何创建DbContext实例的呢?

    前言 上一篇我们简单讲述了在EF Core1.1中如何进行迁移,本文我们来讲讲EF Core1.1中那些不为人知的事,细抠细节,从我做起. 显式创建DbContext实例 通过带OnConfiguri ...

  7. WCF基础

    初入职场,开始接触C#,开始接触WCF,那么从头开始学习吧,边学边补充. SOA Service-Oriented Architecture,面向服务架构,粗粒度.开放式.松耦合的服务结构,将应用程序 ...

  8. [LintCode]——目录

    Yet Another Source Code for LintCode Current Status : 232AC / 289ALL in Language C++, Up to date (20 ...

  9. JQuery实现表格的增加行和删除行

    利用JQuery实现datatables插件的增加和删除行操作 在学习过程中遇到了这个利用JQuery对表格行的增加和删除,特记录下来以供初学者参考. 下面是主要的代码: <meta http- ...

  10. 嵌入式C语言代码的调试技巧

    在项目开发的过程中,不可避免的会遇到调试代码的情况. 刚开始写代码时,我们想看具体执行到哪儿时,往往这么写: printf("***** Code is here! *****\n" ...