javascript条件语句有哪些_if语句和switch该如何使用

JavaScript中最常用条件语句是if和switch:if适用于布尔判断、范围条件及复合逻辑;switch适合等值匹配多个离散固定值,需注意break防穿透和default兜底。

JavaScript 中最常用的条件语句是 if 语句和 switch 语句,它们用于根据不同的条件执行不同的代码块。选哪个取决于判断逻辑的复杂度和可读性。

if 语句:处理布尔条件和多分支逻辑

if 语句适合判断真假值、范围条件、多个独立或嵌套条件。它支持 ifelse ifelse 组合。

  • 基础写法:用括号包裹表达式,结果为真(truthy)时执行花括号内代码
  • 注意隐式转换:0''nullundefinedNaNfalse 是 falsy,其余多数为 truthy
  • 推荐用严格相等 === 避免类型自动转换带来的意外

示例:

let score = 85;
if (score >= 90) {
  console.log("A");
} else if (score >= 80) {
  console.log("B");
} else if (score >= 70) {
  console.log("C");
} else {
  console.log("F");
}

switch 语句:适合等值匹配多个离散值

switch 更适合判断一个变量是否等于若干个**固定值**(如字符串、数字、常量),比一长串 else if 更清晰、更易维护。

  • 每个 case 后必须跟 break,否则会“穿透”执行下一个 case(除非有意为之)
  • default 相当于 else,建议始终加上,提高健壮性
  • 只做全等比较(===),不进行类型转换

示例:

let day = "Monday";
switch (day) {
  case "Monday":
    console.log("Start of week");
    break;
  case "Friday":
    console.log("Almost weekend");
    break;
  default:
    console.log("Just another day");
}

什么时候用 if,什么时候用 switch?

关键看判断依据:

  • 判断范围(如 age > 18)、布尔状态(如 isLoading)、复合条件(如 a && !b)→ 用 if
  • 判断某个值是否等于几个明确选项(如菜单选项、HTTP 状态码、枚举值)→ 优先考虑 switch
  • 现代 JS 中,简单映射也可用对象字面量或 Map 替代 switch,更函数式且易测试

小提醒:别忽略 else 和 default

漏写 elsedefault 不报错,但可能掩盖未覆盖的逻辑分支,导致静默失败。尤其在业务关键路径中,显式处理所有可能情况是好习惯。