当前位置: 首页 > news >正文

第三节:条件语句与循环:控制程序流程

📌 第三节:条件语句与循环:控制程序流程

目标:熟练运用条件判断、循环结构,实现动态逻辑与重复操作,掌握常见算法的底层实现。


一、条件语句:让程序“聪明”起来

1. if-else 基础语法
  • 作用:根据条件执行不同代码块。

  • 语法模板:

    if (条件1) {// 条件1成立时执行
    } else if (条件2) {// 条件2成立时执行
    } else {// 其他情况执行
    }
    
  • 示例:

    let age = 18;
    if (age < 13) {console.log("儿童");
    } else if (age >= 13 && age < 18) {console.log("青少年");
    } else {console.log("成年人"); // 输出:成年人
    }
    
2. 三元运算符(简化版 if-else
  • 语法条件 ? 表达式1 : 表达式2

  • 示例:

    let isMember = true;
    let price = isMember ? 99 : 199; // 会员价 99,非会员 199
    
3. switch 语句:多条件分支
  • 适用场景:替代多个 if-else if,匹配离散值。

  • 语法:

    switch (变量) {case1:// 代码1break;case2:// 代码2break;default:// 其他情况
    }
    
  • 示例:

    let day = "Monday";
    switch (day) {case "Monday":case "Tuesday":case "Wednesday":case "Thursday":case "Friday":console.log("工作日");break;case "Saturday":case "Sunday":console.log("周末");break;default:console.log("无效日期");
    }
    
  • 注意:

    • 每个 case 后需加 break,否则会“穿透”执行后续代码。

二、循环结构:重复执行的高效方式

1. for 循环:经典循环语法
  • 语法:

    for (初始化; 条件; 迭代) {// 循环体
    }
    
  • 示例:

    // 计算 1~10 的和
    let sum = 0;
    for (let i = 1; i <= 10; i++) {sum += i;
    }
    console.log(sum); // 55
    
2. while 循环:先判断后执行
  • 适用场景:循环次数不确定时(如用户输入验证)。

  • 示例:

    let password = "";
    while (password !== "123456") {password = prompt("请输入密码:");
    }
    console.log("登录成功!");
    
3. do-while 循环:先执行后判断
  • 特点:至少执行一次循环体。

  • 示例:

    let num = 0;
    do {console.log(num); // 输出 0num++;
    } while (num > 10); // 条件为 false,但循环体已执行一次
    
4. 循环控制:breakcontinue
  • break:立即终止循环。

    for (let i = 1; i <= 10; i++) {if (i === 5) break; // 输出 1,2,3,4 后终止console.log(i);
    }
    
  • continue:跳过当前迭代,进入下一次循环。

    for (let i = 1; i <= 5; i++) {if (i === 3) continue; // 跳过 3console.log(i); // 输出 1,2,4,5
    }
    
5. 数组遍历:for...offorEach
  • for...of:直接获取元素值(无需索引)。

    let fruits = ["apple", "banana", "orange"];
    for (let fruit of fruits) {console.log(fruit); // 依次输出元素
    }
    
  • forEach:数组方法,接受回调函数。

    fruits.forEach((fruit, index) => {console.log(`${index}: ${fruit}`); // 输出索引和值
    });
    
  • 对比:

    方法是否能 break能否获取索引适用场景
    for...of❌ 不能❌ 需额外声明简单遍历
    forEach❌ 不能✔️ 直接提供函数式编程(链式调用)
    for✔️ 能✔️ 直接声明需要中断或复杂逻辑的循环

三、综合案例:猜数字游戏

目标:实现一个用户输入数字,与随机数比较的猜数字游戏。
代码实现
// 1. 生成随机数(1~100)
const target = Math.floor(Math.random() * 100) + 1;
let attempts = 0;// 2. 循环接收用户输入
while (true) {const guess = parseInt(prompt("猜一个 1~100 的数字:"));attempts++;// 3. 判断结果if (guess === target) {console.log(`🎉 猜对了!用了 ${attempts} 次。`);break; // 退出循环} else if (guess > target) {console.log("太大了!");} else {console.log("太小了!");}
}

四、常见陷阱与优化技巧

1. 死循环
  • 错误示例:

    for (let i = 0; i < 10; i--) { // i-- 导致条件永远成立console.log(i); // 无限输出负数
    }
    
  • 修复方法:确保迭代表达式能改变循环条件。

2. 变量作用域泄漏
  • 错误示例:

    for (let i = 0; i < 3; i++) {setTimeout(() => console.log(i), 100); // 输出 3,3,3(循环已结束)
    }
    
  • 修复方法:

    • 使用 let(块级作用域)或立即执行函数(IIFE)。
    for (let i = 0; i < 3; i++) {setTimeout((j) => console.log(j), 100, i); // 输出 0,1,2
    }
    
3. 性能优化
  • 减少循环内操作:将不变量移到循环外。

    // 低效:每次循环都计算数组长度
    for (let i = 0; i < arr.length; i++) { ... }// 高效:缓存长度
    const len = arr.length;
    for (let i = 0; i < len; i++) { ... }
    

五、课后任务

基础任务
  1. if-else 判断一个数字是正数、负数还是零。
  2. while 循环计算 1~100 的偶数和。
  3. for...of 遍历数组并输出每个元素的平方。
进阶任务
  1. 改进猜数字游戏,限制最多 5 次猜测机会。

  2. 用嵌套循环打印九九乘法表:

    1×1=1
    1×2=2 2×2=4
    ...
    

📌 关键点总结

  1. 条件语句:
    • if-else 适合复杂条件,switch 适合离散值匹配。
  2. 循环结构:
    • for 适合已知次数,while 适合未知次数,for...of 适合数组遍历。
  3. 性能与陷阱:
    • 避免死循环,注意变量作用域,优化循环内操作。

🎯 下一节预告

「函数:代码复用的魔法」

  • 掌握参数传递、返回值、作用域链的底层原理。
  • 破解闭包与高阶函数的实战应用。
  • 动手实现一个计算器模块。

如果需要调整内容深度或补充示例(如更详细的 VSCode 调试配置),可以随时告诉我! 😊

http://www.xdnf.cn/news/356869.html

相关文章:

  • 特殊配合力(SCA)作为全基因组关联分析(GWAS)的表型,其生物学意义和应用价值
  • MQTT:轻量级物联网通信协议详解
  • Vulnhub Lazysysadmin靶机攻击实战(一)
  • logback日志输出到项目运行目录
  • Git_idea界面进行分支合并到主分支详细操作
  • Elasticsearch内存管理与JVM优化:原理剖析与最佳实践
  • 两款Windows小工具,不收费还好用
  • 【网工第6版】第9章 网络管理
  • C语言实现小波变换去噪
  • 虚拟专用服务器(VPS)完全指南:从入门到选型
  • 红色大banner的wordpress免费模板
  • 【各种坐标系】
  • 学习笔记:黑马程序员JavaWeb开发教程(2025.3.31)
  • AI汽车时代的全面赋能者:德赛西威全栈能力再升级
  • k8s存储类型:emptyDir、hostPath、nfs、pvc及存储类storageclass的静态/动态创建pv
  • 从电动化到智能化,法雷奥“猛攻”中国汽车市场
  • 使用 ECharts GL 实现交互式 3D 饼图:技术解析与实践
  • Python在大数据机器学习模型的多模态融合:深入探索与实践指南
  • C++ - 函数重载
  • python中,什么是协程?
  • SQLite 转换为 MySQL 数据库
  • LlamaIndex 第六篇 SimpleDirectoryReader
  • vue数据可视化开发常用库
  • OpenCV播放摄像头视频
  • LeetCode 热题 100_编辑距离(94_72_中等_C++)(动态规划)
  • Rust 官方文档:人话版翻译指南
  • 高拟人化客服机器人显著提升用户接受度
  • zst-2001 历年真题 UML
  • 首版次软件测试的内容有哪些?首版次软件质量影响因素是什么?
  • IAR无法显示文件列表(即workspace)