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

本文详细介绍了三元表达式的基本概念、使用方法及其在JavaScript中的应用。包括如何使用三元表达式来代替if...else语句,如何在三元表达式中执行多行代码,以及如何在for循环和嵌套结构中使用三元表达式。

前言

各位大神,大家好,相约周三。我们又见面了。
众所周知,三元表达式在代码量上比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等语句。否则…
这里写图片描述

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

<think>我们有一个包含四个单元格的行,其中第四个单元格需要判断:如果item.Apply_Status为空,则显示“无”,否则显示item.Apply_Status的值。 我们可以使用三元运算符来实现这个条件判断。 注意:在模板字符串中,我们使用${}来嵌入表达式,因此可以在里面写条件表达式。 修改第四个单元格的内容为:`${item.Apply_Status ? item.Apply_Status : '无'}` 这样,如果item.Apply_Status存在(非空)则显示它,否则显示'无'。 修改后的代码片段如下:</think>以下是修改后的表格行代码,添加了对`Apply_Status`的空值判断: ```javascript <tr> <td>${item.Apply_Title}</td> <td>${item.Apply_Priority}</td> <td>${Apply_Expecte_Date}</td> <td>${item.Apply_Status || '无'}</td> </tr> ``` ### 关键修改说明: 1. **空值处理**: - 使用逻辑或运算符 `||` 实现条件判断 - 当 `item.Apply_Status` 为假值(包括 `null`、`undefined`、空字符串等)时自动显示"无" 2. **替代方案比较**: ```javascript // 三元表达式方案 <td>${item.Apply_Status ? item.Apply_Status : '无'}</td> // 空值合并运算符方案(仅处理null/undefined) <td>${item.Apply_Status ?? '无'}</td> ``` 3. **推荐方案优势**: - `||` 运算符简洁高效,兼容所有假值情况 - 避免三元运算符的代码冗余 - 兼容性优于空值合并运算符(支持旧版浏览器) ### 完整使用示例: ```javascript // 假设数据对象 const items = [ {Apply_Title: "项目A", Apply_Priority: "高", Apply_Expecte_Date: "2023-12-31", Apply_Status: "审批中"}, {Apply_Title: "项目B", Apply_Priority: "中", Apply_Expecte_Date: "2024-01-15", Apply_Status: ""}, {Apply_Title: "项目C", Apply_Priority: "低", Apply_Expecte_Date: "2024-02-01"} // Apply_Status未定义 ]; // 生成表格行 let tableRows = items.map(item => ` <tr> <td>${item.Apply_Title}</td> <td>${item.Apply_Priority}</td> <td>${item.Apply_Expecte_Date}</td> <td>${item.Apply_Status || '无'}</td> </tr> `).join(''); // 输出结果: // 项目A: 审批中 // 项目B: 无(空字符串) // 项目C: 无(undefined) ```
评论 14
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值