<Javascript>浅谈js“三元表达式” (三元运算符)

<Javascript>浅谈js“三元表达式” (三元运算符)前言各位大神,大家好,相约周三。我们又见面了。众所周知,三元表达式在代码量上比if…else语句更简洁一些。但是博主刘少在可读性上更加偏向于if…else语句。三元表达式不仅在js中使用,在很多后台程序语言,比如java、php中都有使用,不过在js中对于三元表达式的要求貌似要松很多。废话不多说。下面一起看看三元表达式。三元表达式素质N连问首先为什么叫三元表达式?顾…

大家好,又见面了,我是你们的朋友全栈君。

前言

各位大神,大家好,相约周三。我们又见面了。
众所周知,三元表达式在代码量上比if…else语句更简洁一些。但是博主在可读性上更加偏向于if…else语句。三元表达式不仅在js中使用,在很多后台程序语言,比如java、php中都有使用,不过在js中对于三元表达式的要求貌似要松很多。废话不多说。下面一起看看三元表达式。

三元表达式

素质N连问

首先 为什么叫三元表达式?
顾名思义,有三个元素组成的表达式。

哪三个元素呢?
“条件”“真结果”“假结果”。

三元表达式的基本格式是什么呢?
条件?真结果:假结果

三元表达式是如何对应if…else语句的?
条件 ? 真结果 : 假结果
if(条件){真结果}else{假结果}

我们来看一下官方的解释。W3C把“三元表达式”叫做”ECMAScript 条件运算符”这里写图片描述
诶!中间为什么空了一块呢?
我给它补上:
boolean_expression ? true_value : false_value
这行代码的意思官方也给了具体的说明,这里不再赘述。

三元表达式结果执行多行代码表达:

大家也看到了,在官方的w3c文档中,给的只有一条结果执行语句,但是博主之前说过,至少在js中,三元表达式和if…else语句是可以相互替换的。
那么既然if…else语句都可以在结果执行时写多行代码,三元表达式为什么不行呢?
其实是可以的。

		<script>
		var a='';
		var b='';
		var age=prompt("Input your age:");
		age>18 ? (a='成年人',b='18岁以上') : (a='未成年人',b='18岁以下');
		alert(a);
		alert(b);
		</script>

这下看明白了吗?只要在结果中多条语句之间加上“,”就可以了。

三元表达式在for循环中的运用

<script>
		var a='';
		var b='';
		for(var i=0;i<4;i++){
			i>2 ? (a='成年人',b='18岁以上') : (a='未成年人',b='18岁以下');
			alert(a);
			alert(b);
		}
		</script>

以上代码打印一次 ‘成年人’,‘18岁以上’ 三次‘ 未成年人’,‘18岁以下’。(此处感谢 @nimapier 指出错误)

三元表达式的嵌套
if…else语句可以嵌套多层,那想必三元表达式也可以进行嵌套吧!没错,三元表达式可以进行嵌套,而且理论上可以无限嵌套下去。为什么说理论上?因为暂时没有见过有人嵌套过多行三元表达式。首先不利于代码的阅读,其次对于逻辑能力不强的人来说,确实是一种脑力的摧残!大家自行感受一下。

		<script>
		var a='';
		var b='';
		var age=prompt("Input your age:");
			age<18 ?  (a='儿童',b='18岁以下'):( age>50 && age<80 ? (a='老年人',b='50岁以上') : (age>=80 ? (a='长寿者',b='80岁以上'):(a='你的年龄是以下两种',b='18、50')));
			alert(a);
			alert(b);
		</script>

其实这块代码看起来感觉还不是很明显,但是博主在调试过程中已经有点晕了,特别是在最后三个括号那里,纠结了!

所以归纳一下三元表达式的嵌套:
条件1 ? 真结果1:( 条件1.1 真结果1.1 : (条件1.1.1 ? 真结果1.1.1:假结果1.1.1))
简便的写法可以不用括号
是不是眼睛都看花了?

三元表达式的局限性

最后,大家注意,三元表达式在使用过程中不能使用break,continue等语句。否则…
这里写图片描述

最最后谢谢各位大神赏脸阅读鄙人拙劣的博客。撰写不恰当之处还希望各位大佬指出共同学习。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159737.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IDEA打包maven项目同时带上依赖

    IDEA打包maven项目同时带上依赖我们在使用IDEA中maven的LifeCycle去打包时,打出的jar包只包含代码,在使用时会出现“找不到包或者无法加载“ClassNotFoundException”报错。这是因为我们的jar包没有maven项目中的其他依赖包,所以我们可以在打包时把依赖也打入到jar包中,步骤如下:1、选中项目,点击File,选择打开“ProjectStructure”2、然后选择左边的“Artifacts”,点击“加号”添加jar包,“Frommodul…

    2022年5月30日
    203
  • eclipse集成svn使用_svn常用命令

    eclipse集成svn使用_svn常用命令在新版本的Eclipse中是没有svn这个插件,如果我们要用,不得不自己去集成SVN(我不知道老版当中有没有这个插件,没太注意这个问题),今天给大家带来2种集成的方式,一种是在线集成,另一种否是离线集成。这也是我目前知道的2种方案,我也不清楚还有没有其它方案。1.在线集成:Name:这个可以任意添,没有硬性规定,最好见名知意。Location:http://subclipse.tigris.org…

    2022年9月26日
    0
  • python数据库操作之sqlalchemy逆向工程

    python数据库操作之sqlalchemy逆向工程依赖安装pipinstallsqlacodegen数据库配置config.pyimportosHOST=’localhost’PORT=3306USERNAME=’root’PASSWORD=’root’DB=’demo’DB_URI=f’mysql+pymysql://{USERNAME}:{PASSWORD}@{HOST}:{PORT}/{DB}’#自动生成modelsos.system(f’sqlacodegen{DB_URI}

    2022年6月22日
    33
  • IIFE详解

    IIFE详解介绍 IIFE IIFE 的性能 使用 IIFE 的好处 IIFE 最佳实践 jQuery 优化 nbsp 在 Bootstrap 源码 具体请看 Bootstrap 源码解析 和其他 jQuery 插件经常看到如下的写法 nbsp function window jQuery nbsp 这种写法称为 IIFE nbsp ImdiatelyInv

    2025年6月5日
    0
  • 服务器中了挖矿病毒怎么办

    服务器中了挖矿病毒怎么办前言服务器好端端的竟然中了挖矿病毒!!!可怜我那1核2G的服务器,又弱又小,却还免除不了被拉去当矿工的命运,实在是惨啊惨。事情原来是这样的。。。就在今天下午,我准备登陆自己的远程服务器搞点东西的时候,突然发现ssh登陆不上了。如上,提示被拒绝。这个问题很明显就是服务器没有我的公钥,或者不识别我的公钥,然后拒绝登录。这就很难办了,我确定我的公钥是一直没有变动过的,不应该会出现这种情况啊。还有让我头疼的是,我当初为了安全起见,设置过此台服务器只能通过ssh的方式

    2022年6月3日
    102
  • JVM 内存模型概述

    JVM 内存模型概述Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域,这些数据区域都有各自的用途,以及创建和销毁的时间,并且它们可以分为两种类型:线程共享的方法区和堆,线程私有的虚拟机栈、本地方法栈和程序计数器。在此基础上,我们探讨了在虚拟机中对象的创建和对象的访问定位等问题,并分析了Java虚拟机规范中异常产生的情况。

    2022年6月12日
    30

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号