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

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

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

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


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

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 调试配置),可以随时告诉我! 😊

相关文章:

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

&#x1f4cc; 第三节&#xff1a;条件语句与循环&#xff1a;控制程序流程 目标&#xff1a;熟练运用条件判断、循环结构&#xff0c;实现动态逻辑与重复操作&#xff0c;掌握常见算法的底层实现。 一、条件语句&#xff1a;让程序“聪明”起来 1. if-else 基础语法 作用&am…...

荣耀A8互动娱乐组件部署实录(第1部分:服务端环境搭建)

作者&#xff1a;一位被“只支持安卓”的前端劝退过三次的技术人 前言 这一套组件我拆包已经不止一遍了&#xff0c;老实讲&#xff0c;不支持 iOS 是遗憾&#xff0c;但对于研究 UI 动态加载、资源分离结构和整体架构来说&#xff0c;A8 的这套服务还算完整&#xff0c;服务器…...

流式渲染 Streaming SSR

以下是关于流式渲染(Streaming SSR)的基本知识点总结: 一、流式渲染核心概念 1. 与传统SSR对比 维度传统SSR流式SSR响应方式完整HTML生成后一次性返回分块逐步返回HTML内容首字节时间较慢(需等待所有数据处理完成)极快(立即发送初始HTML结构)内存压力高(需缓存完整页面…...

基于Python Flask的深度学习电影评论情感分析可视化系统(2.0升级版,附源码)

博主介绍&#xff1a;✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3…...

如何减少极狐GitLab 容器镜像库存储?

极狐GitLab 是 GitLab 在中国的发行版&#xff0c;关于中文参考文档和资料有&#xff1a; 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 减少容器镜像库存储 (BASIC ALL) 未清理的容器镜像库会随着时间的推移而变大。添加大量镜像或标签时&#xff1a; 获取可用标…...

计算机学习路线与编程语言选择(信息差)

——授人以鱼不如授人以渔 计算机学习公式&#xff1a;1/3科班思维 1/3路线选择 1/3工程能力 好工作随便找&#xff08;来自B站小毛毛熊&#xff09; 本文主要是路线选择&#xff01;&#xff01;&#xff01;下面开始吧。 面向岗位学习&#xff01;到招聘网站看看有哪些…...

【redis】redis 手动切换主从

场景一&#xff1a; 测试需要&#xff0c;需要手动切换主从 在redis节点&#xff1a; $ redis-cli -h xx.xx.xx.xx -p XX -a XX shutdown 不要直接关闭redis进程&#xff0c;使用 shutdown &#xff0c;能在进程关闭前持久化内存中的数据 待主从切换完毕后&#xff1…...

基于设备指纹识别的反爬虫技术:给设备办 “身份证”

传统的封禁 IP、验证码等反爬虫手段已逐渐失效&#xff0c;基于设备指纹识别的反爬虫技术应运而生&#xff0c;成为守护数据安全的新防线。它如同给每个设备办一张独一无二的 “身份证”&#xff0c;精准区分正常用户与爬虫工具。 一、基础参数采集&#xff1a;构建设备指纹的…...

SpringAI框架中的RAG知识库检索与增强生成模型详解

SpringAI框架中的RAG知识库检索与增强生成模型详解 一、RAG简介 RAG&#xff08;Retrieval-Augmented Generation&#xff09;可以通过检索知识库&#xff0c;克服大模型训练完成后参数冻结的局限性&#xff0c;携带知识让大模型根据知识进行回答。 二、SpringAI框架支持的R…...

【造包工具】【Xcap】精讲Xcap构造分片包(IPv4、ipv6、4G\5G等pcap均可),图解超赞超详细!!!

目录 前言 1. XCap工具概念介绍 2. Xcap环境说明 2.1 新建报文组 2.2 导入数据包 2.3 查看报文组 2.4 复制删除报文组 3. 构造分片包 3.1 造普通/外层分片步骤: 3.2 造内层分片步骤 3.2.1 建立一个新报文 3.2.2 将组装的新报文分片 3.2.3 替换原始包内层部分 3.2…...

第三节:Vben Admin 最新 v5.0 对接后端登录接口(下)

文章目录 前言一、处理请求头Authorization二、/auth/user/info 接口前端接口后端接口三、/auth/codes 接口1.前端2.后端四、测试接口前言 上一节内容,实现了登录的/auth/login 接口,但是登陆没有完成,还需要完成下面两个接口。才能完成登录。 一、处理请求头Authorizatio…...

爬虫学习————开始

&#x1f33f;自动化的思想 任何领域的发展原因————“不断追求生产方式的改革&#xff0c;即使得付出与耗费精力越来愈少&#xff0c;而收获最大化”。由此&#xff0c;创造出方法和设备来提升效率。 如新闻的5W原则直接让思考过程规范化、流程化。或者前端框架/后端轮子的…...

Ubuntu18.04搭建samda服务器

一.什么是Samba服务器&#xff1f; Samba服务器是一种基于开源协议实现的网络共享服务软件&#xff0c;主要用于在不同操作系统&#xff08;如Windows、Linux、Unix&#xff09;之间实现文件和打印机共享功能。其核心目标是解决跨平台资源共享的兼容性问题&#xff0c;尤其是在…...

K8S扩缩容及滚动更新和回滚

目录&#xff1a; 1、滚动更新1、定义Deployment配置2、应用更新 2、版本回滚1. 使用kubectl rollout undo命令 3、更新暂停与恢复1、暂停更新2、更新镜像&#xff08;例如&#xff0c;使用kubectl set image命令&#xff09;3、恢复更新 4、弹性扩缩容1、扩容命令2、缩容命令3…...

一文掌握 LVGL 9 的源码目录结构

文章目录 &#x1f4c2; 一文掌握 LVGL 9 的源码目录结构&#x1f9ed; 顶层目录概览&#x1f4c1; 1. src/ — LVGL 的核心源码&#xff08;&#x1f525;重点&#xff09;&#x1f4c1; 2. examples/ — API 示例&#x1f4c1; 3. demos/ — 综合演示项目&#x1f4c1; 4. do…...

2025-05-10-FFmepg库裁切有水印的视频

裁后 代码 import subprocess# 文件路径 input_video_path "bg_video.mp4" output_video_path "output_video_cropped.mp4"# 裁剪视频下方的水印 def crop_video(input_video_path, output_video_path, crop_height):# 获取视频的分辨率def get_video…...

Vue3 路由配置与跳转传参完整指南

目录 一、路由配置 1. 基本路由配置 2. 动态路由配置 3. 可选参数配置 二、路由跳转与传参 1. 声明式导航 (模板中) 2. 编程式导航 (JavaScript中) 三、参数接收 1. 接收动态路由参数 2. 接收查询参数 3. 监听参数变化 四、高级用法 1. 路由元信息 2. 路由守卫控…...

opencv+opencv_contrib+cuda和VS2022编译

本文介绍使用OpenCV和OpenCV_Contrib源码及Cuda进行编译的过程&#xff0c;编译过程中会用到OpenCV、OpenCV_Contrib、CUDA Toolkit、cuDNN、Cmake、VS2022等工具&#xff0c;最终编译OpenCV的Cuda版本。 一、OpenCV下载地址 OpenCV官网下载地址:https://opencv.org/releases…...

《深挖Java中的对象生命周期与垃圾回收机制》

大家好呀&#xff01;&#x1f44b; 今天我们要聊一个Java中超级重要的话题——对象的生命周期和垃圾回收机制。 一、先来认识Java世界的"居民"——对象 &#x1f476; 在Java世界里&#xff0c;一切皆对象。就像现实世界中的人一样&#xff0c;每个Java对象也有自…...

C++中extern关键字详解:不同情况下的使用方式

在 C 中&#xff0c;extern 关键字主要用于声明变量或函数是在其他文件中定义的&#xff0c;从而可以在当前文件中使用这些变量或函数。下面详细介绍 extern 修饰全局变量、函数等的用法区别以及注意事项。 修饰全局变量 详细介绍 当 extern 用于修饰全局变量时&#xff0c;…...

【QT】深入理解 Qt 中的对象树:机制、用途与最佳实践

深入理解 Qt 中的对象树&#xff1a;机制、用途与最佳实践 在使用 Qt 编程时&#xff0c;你是否注意到很多对象可以设置“父对象”&#xff1f;比如&#xff1a; QPushButton* btn new QPushButton(parentWidget);这不是简单的层级结构&#xff0c;而是 Qt 强大而优雅的 对象…...

如何利用爬虫获得1688商品详情:实战指南

在电商运营和市场分析中&#xff0c;获取1688商品详情数据是一项重要任务。本文将详细介绍如何利用爬虫技术获取1688商品详情&#xff0c;包括准备工作、爬虫实现步骤以及注意事项。 一、准备工作 &#xff08;一&#xff09;注册1688开放平台账号 在1688开放平台注册开发者…...

网工实验——OSPF配置

网络拓扑图 配置 1.为每个路由器配置接口&#xff08;略&#xff09;&#xff08;详细见RIP实验&#xff09; 2.配置OSPF AR1 [AR1]ospf [AR1-ospf-1]area 1 [AR1-ospf-1-area-0.0.0.1]network 172.16.1.1 0.0.0.0 #精确配置网络&#xff0c;也可以像下面那条命令那样配置 …...

数据库系统概论-基础理论

数据库系统概述&#xff1a; 1、记录&#xff1a;计算机中表示和存储数据的一种格式或方法。 2、数据库&#xff08;DataBase, DB&#xff09;&#xff1a;数据库是长期储存在计算机内、有组织、可共享的大量数据集合。可为各种用户共享。 3、数据库管理系统&#xff08;Dat…...

从零开始学习人工智能(Python高级教程)Day6-Python3 正则表达式

一、Python3 正则表达式 正则表达式是一个特殊的字符序列&#xff0c;它能帮助你方便的检查一个字符串是否与某种模式匹配。 在 Python 中&#xff0c;使用 re 模块来处理正则表达式。 re 模块提供了一组函数&#xff0c;允许你在字符串中进行模式匹配、搜索和替换操作。 r…...

Qt开发:项目视图(Item Views)的介绍和使用

文章目录 一、清单视图&#xff08;List View&#xff09;1.1 基本概念1.2 使用示例&#xff08;文字列表&#xff09;1.3 图标文字&#xff08;图标模式&#xff09;1.4 常用设置1.5 完整示例 二、树视图&#xff08;Tree View&#xff09;2.1 基本概念2.2 常用类简介2.3 快速…...

“ES7+ React/Redux/React-Native snippets“常用快捷前缀

请注意&#xff0c;这是一个常用的列表&#xff0c;不是扩展提供的所有前缀。最完整和最新的列表请参考扩展的官方文档或在 VS Code 中查看扩展的详情页面。 React (通常用于 .js, .jsx, .ts, .tsx): rfce: React Functional Component with Export Defaultrafce: React Arro…...

keepalived详细笔记

keepalived 是一种基于VRRP&#xff08;虚拟路由器冗余协议&#xff09;的高可用解决方案&#xff0c;主要是用于服务器的负载均衡和高可用性的保障&#xff0c;自动将服务切换到备份服务器上&#xff0c;确保业务的连续性。 工作原理&#xff1a; VRRP协议&#xff1a;一组路…...

xLua笔记

Generate Code干了什么 肉眼可见的&#xff0c;在Asset文件夹生成了XLua/Gen文件夹&#xff0c;里面有一些脚本。然后对加了[CSharpCallLua]的变量寻找引用&#xff0c;发现它被XLua/Gen/DelegatesGensBridge引用了。也可以在这里查哪些类型加了[CSharpCallLua]。 public over…...

一周学会Pandas2 Python数据处理与分析-Pandas2数据排序操作

锋哥原创的Pandas2 Python数据处理与分析 视频教程&#xff1a; 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Pandas 2提供了多种灵活的数据排序方法&#xff0c;主要针对 DataFrame 和 Series 对象。 1. 按值排序&#xff1a;s…...