JavaScript中的条件语句主要包括if...else、switch和三元运算符,用于根据不同条件执行相应代码块;if...else适用于复杂条件和范围判断,switch适合单一变量的多个离散值匹配,三元运算符用于简洁的二元选择,而逻辑短路(&&、||)、空值合并(??)和可选链(?.)等特性则提供了更灵活的条件控制方式,提升代码简洁性与健壮性,但需权衡可读性与维护性,最终选择应基于具体场景和代码清晰度需求。

JavaScript中的条件语句,说白了,就是程序根据不同的情况去执行不同的代码块。最核心的写法无非就是
if...else
switch
我们来细致地聊聊这些常见的条件语句写法。
1. if...else if...else
let score = 85;
if (score >= 90) {
console.log("优秀!");
} else if (score >= 80) {
console.log("良好。");
} else if (score >= 60) {
console.log("及格。");
} else {
console.log("不及格。");
}这种结构在处理复杂、多分支且条件之间可能存在重叠或范围判断时特别有用。你可以嵌套
if
2. switch
switch
if...else if
let dayOfWeek = "Monday";
switch (dayOfWeek) {
case "Monday":
console.log("一周的开始,加油!");
break; // 别忘了break,否则会“穿透”到下一个case
case "Friday":
console.log("周末要来了,开心!");
break;
case "Saturday":
case "Sunday": // 多个case可以共用一个代码块
console.log("享受你的周末吧!");
break;
default:
console.log("普通工作日。");
}switch
===
case
break
case
case
default
3. 三元运算符(Ternary Operator) 这是一种非常简洁的条件表达式,通常用于根据一个条件给变量赋值或者返回一个值。
let age = 18;
let status = (age >= 18) ? "成年人" : "未成年人";
console.log(status); // 输出: 成年人
// 也可以用于简单的函数返回
function canVote(age) {
return (age >= 18) ? true : false;
}
console.log(canVote(17)); // 输出: false它的语法是
条件 ? 表达式1 : 表达式2
表达式1
表达式2
在我个人的经验里,选择
if/else
switch
if/else
score >= 90
age > 18 && hasLicense
if/else
而
switch
status
"pending"
"approved"
"rejected"
switch
if (status === "pending") ... else if (status === "approved") ...
但
switch
case score > 90:
break
switch
if/else
三元运算符,简直是代码精简的利器,尤其是在你只需要根据一个布尔条件来决定一个值的场景。它的“妙用”在于能让代码变得非常紧凑,一行就能搞定赋值或者简单的返回逻辑,对于那些追求函数式编程风格、喜欢表达式而非语句的开发者来说,它简直是福音。比如,给一个变量设置默认值,或者根据用户权限显示不同文本,用它写起来就特别顺畅。
// 妙用:简洁的赋值 const message = isLoggedIn ? "欢迎回来!" : "请登录。"; // 妙用:函数内直接返回 const getPrice = (isVip) => isVip ? 99 : 120;
然而,这把“利器”也有它的“陷阱”。最大的问题就是可读性。当你的条件或者表达式变得复杂时,三元运算符会迅速变得难以理解,甚至比嵌套的
if/else
// 陷阱:嵌套过深,可读性差 const finalStatus = (user.isPremium ? (user.isActive ? "Premium Active" : "Premium Inactive") : (user.isGuest ? "Guest" : "Standard User")); // 这种情况下,还是老老实实写if/else更清晰
我的建议是,把三元运算符留给那些简单、直观的二元选择。如果你的条件或者结果表达式需要多行代码,或者逻辑本身比较复杂,那么请毫不犹豫地使用
if/else
除了上面那些“正规军”,JavaScript里还有一些利用其特性实现的“非典型”条件控制,它们常常能让代码更优雅、更高效。
1. 逻辑与(&&
&&
false
0
""
null
undefined
NaN
let userLoggedIn = true;
userLoggedIn && console.log("用户已登录,可以访问!"); // 如果userLoggedIn为true,则执行console.log
// 常见的应用:条件渲染(在React/Vue等框架中很常见)
// showModal && <ModalComponent />这种写法非常简洁,尤其适合当你的“条件满足时执行某个操作”的场景。
2. 逻辑或(||
&&
||
let userName = ""; // 假设从某个地方获取,可能为空
let displayName = userName || "访客"; // 如果userName是空字符串(假值),则使用"访客"
console.log(displayName); // 输出: 访客
let userConfig = null;
let config = userConfig || { theme: 'dark', language: 'en' }; // 如果userConfig为null(假值),则使用默认配置
console.log(config); // 输出: { theme: 'dark', language: 'en' }这个技巧在处理可能为
null
undefined
3. 空值合并运算符(??
||
??
null
undefined
||
0
""
false
let response = 0; // 假设后端返回0,这是个有效值 let count = response ?? 100; // 如果用||,count会是100;用??,count是0 console.log(count); // 输出: 0 let setting = ''; // 空字符串,在某些场景下也是有效值 let displaySetting = setting ?? 'Default'; console.log(displaySetting); // 输出: ''
当你需要区分
null
undefined
0
""
??
||
4. 可选链操作符(?.
?.
null
undefined
const user = {
profile: {
address: {
street: "Main St"
}
}
};
// 尝试安全地访问深层嵌套的属性
const streetName = user?.profile?.address?.street;
console.log(streetName); // 输出: Main St
const adminUser = null;
const adminAddress = adminUser?.profile?.address?.street;
console.log(adminAddress); // 输出: undefined,而不是报错这让处理复杂数据结构时,代码变得更加健壮,避免了冗长的
if (user && user.profile && user.profile.address)
这些“变体”和“进阶”用法,在我看来,是JavaScript灵活性的体现。它们不直接是
if/else
以上就是JS条件语句有哪些写法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号