JavaScript流程控制,带你打印九九乘法表

简介: JavaScript流程控制,带你打印九九乘法表

📜个人简介

⭐️ 个人主页: 微风洋洋🙋‍♂️
🍑 博客领域:编程基础,后端
🍅 写作风格:干货,干货,还是tmd的干货
🌸 精选专栏【JavaScript】
🚀 支持洋锅:点赞👍、收藏⭐、留言💬

好久不见,甚是想念!
大家好!我是微风洋洋

今天这篇文章就是来和大家详细聊聊JavaScript中程序流程控制,顺便解决一下打印金字塔和九九乘法表这件趣事,希望大家读完有所收获,那我辛苦码字也就值了。

@TOC

一、选择结构

概念:选择结构语句需要根据给出的条件进行判断来决定执行对应的代码。

在这里插入图片描述


🌴if单分支语句

概念:if条件判断语句也被称为单分支语句,当满足某种条件时,就进行某种处理。

举例:只有年龄大于等于18周岁,才输出已成年,否则无输出。

在这里插入图片描述


🌴if…else双分支语句

概念:if…else语句也称为双分支语句,当满足某种条件时,就进行某种处理,否则进行另一种处理。

举例:判断一个学生的年龄,大于等于18岁则是成年人,否则是未成年人。

在这里插入图片描述


🌴if…else if…else多分支语句

概念:if…else if…else语句也称为多分支语句,可针对不同情况进行不同的处理。

举例:对一个学生的考试成绩进行等级的划分,分数在90——100分为优秀,分数在80——90分为优秀为良好,分数在70——80分为中等,分数在60——70分为及格,分数小于60则为不及格。

在这里插入图片描述


📌注意

“if…else if…else”语句在使用时,“else if”中间要有空格,否则程序会报语法错误。

在这里插入图片描述


🌴switch多分支语句

概念:switch语句也是多分支语句,功能与if系列条件语句相同,不同的是它只能针对某个表达式的值作出判断,从而决定执行哪一段代码。

特点:代码更加清晰简洁、便于阅读。

举例:根据学生成绩score进行评比(满分为100分)。

在这里插入图片描述

在这里插入图片描述



二、循环结构

概念:所谓循环语句就是可以实现一段代码的重复执行。

举例:连续输出1~100之间的数字。

在这里插入图片描述


🌴while循环语句

概念:while循环语句是根据循环条件来判断是否重复执行一段代码。

在这里插入图片描述

📌注意

需要注意的是,若循环条件永远为true时,则会出现死循环,因此在开发中应根据实际需要,在循环体中设置循环出口,即循环结束的条件。


🌴do…while循环语句

do…while循环语句的功能与while循环语句类似,唯一的区别在于,while是先判断条件后执行循环体,而do...while会无条件执行一次循环体后再判断条件。

在这里插入图片描述


🌴for循环语句

概念:for循环语句是最常用的循环语句,它适合循环次数已知的情况。

在这里插入图片描述

for关键字后面小括号“()”中包括了三部分内容:

  • 初始化表达式。
  • 循环条件。
  • 操作表达式。

它们之间用“;”分隔,{}中的执行语句为 ③循环体。

在这里插入图片描述

📌注意

for循环语句小括号“()”内的每个表达式都可以为空,但是必须保留分号分割符。当每个表达式都为空时,表示该for循环语句的循环条件永远满足,会进入无限循环的状态,此时如果要结束无限循环,可在for语句循环体中用跳转语句进行控制。



三、跳转语句

概念:跳转语句用于实现程序执行过程中的流程跳转。

常用的跳转语句:有break和continue语句。

break与continue的区别:break语句可应用在switch和循环语句中,其作用是终止当前语句的执行,跳出switch选择结构或循环语句,执行后面的代码。而continue语句用于结束本次循环的执行,开始下一轮循环的执行操作。


其他功能:break和continue语句还可跳转到指定的标签语句处,实现嵌套语句的多层次跳转。

  • label表示标签的名称,如start、end等任意合法的标识符。
  • statement表示具体执行的语句,如if、while、变量的声明等。
  • 标签语句必须在使用之前定义,否则会出现找不到标签的情况。

在这里插入图片描述



【案例】打印金字塔

QQ截图20220212224900.png

代码实现思路:

  • 分析金字塔组成:由空格和星星“*”组成的三角形。
  • 分析“*”和空格的分布规律(假设最上面的一个星星作为金字塔的第一层)。
  • 每层中星星的数量 = 当前层数2 -1。例如当前为第4层,则星星数= 42-1=7。
  • 每层星星前的空格 = 金字塔层数 – 当前层数。例如当前行数为第3层,则空格数=5-3=2。

代码实现

    <script>
    var level = prompt('请设置金字塔的层数');
    // 获取输入的纯数字,其余情况皆转为NaN
    level = parseInt(level);
    // 判断用户输入的数据是否合法
    if (isNaN(level)) {
    alert('金字塔的层数必须是纯数字');
    }
    // 循环遍历金字塔的层数
    for(var i = 1; i <= level; ++i){
    // 输出星星前的空格
    var blank = level - i;
    for(var k=0; k < blank; ++k){
    document.write('&nbsp;');
    }
    // 打印星星
    var star = i*2 - 1;
    for(var j = 0; j < star; ++j){
    document.write('*');
    }
    // 换行
    document.write('<br>');
    }
    </script>



四、动手实践九九乘法表

九九乘法表体现了数字之间乘法的规律,成为了学生在学习数学时必不可少的一项内容。

QQ截图20220212225153.png
代码实现

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>九九乘法表</title>
    <style>
    table{border-collapse:collapse;}
    table td{border:2px solid #ccc;padding:3px 6px;}
    </style>
    </head>
    <body>
    <table>
    <script>
    
    for (var i = 1; i < 10; ++i) { // 遍历表中所有的行
    document.write('<tr>');
    for (var j = 1; j <= i; ++j) { // 遍历每行中的列
    // 拼接单元格
    document.write('<td>');
    document.write(j);
    document.write('×');
    document.write(i);
    document.write('=');
    document.write(j * i);
    document.write('</td>');
    }
    document.write('</tr>');
    }
    
    </script>
    </table>
    </body>
    </html>


如果觉得这篇文章对你有一丢丢启发的话,不妨 点赞👍、收藏⭐、留言💬支持一下,你的支持将是我继续创作的最大动力❤️❤️❤️

由于作者水平有限,如有错误和不准确之处在所难免,本人也很想知道这些错误,恳望读者批评指正!

if (学会了){
点个赞,给个好评,我祝福你心想事成;
}else{
收藏一下以后慢慢学,我相信你能学会;
}
相关文章
|
8月前
|
JavaScript 前端开发 算法
设计一个简单的JavaScript版“俄罗斯方块”游戏的基本逻辑流程。
```md 设计JavaScript版俄罗斯方块游戏涉及初始化环境、创建游戏容器、管理变量、加载音效。游戏循环中生成方块、键盘控制移动与旋转、碰撞锁定、行消除及分数更新。当游戏区域填满时结束游戏,显示结束画面。还包括暂停、重置等辅助功能。伪代码示例展示了核心逻辑,实际实现需考虑更多细节和用户体验增强。 ```
173 3
|
8月前
|
Web App开发 JavaScript 前端开发
Node.js 的事件循环原理、工作流程
Node.js 的事件循环原理、工作流程
122 0
|
8月前
|
JavaScript 前端开发 开发者
从0开始学习JavaScript--JavaScript 流程控制
JavaScript中的流程控制结构是编写结构化、可读性强的代码的关键。本文将深入研究JavaScript中的流程控制,包括条件语句、循环结构、跳转语句等,并通过丰富的示例代码来更全面地了解和运用这些概念。
|
8月前
|
Android开发
Autox.js 脚本开发环境搭建,从案例到打包apk(详细流程)
Autox.js 脚本开发环境搭建,从案例到打包apk(详细流程)
2217 0
|
4月前
|
JavaScript 前端开发
JavaScript基础知识-流程控制之while循环
这篇文章介绍了JavaScript中的while循环和do...while循环的基础知识,并通过一个实际案例演示了如何使用while循环计算投资增长到特定金额所需的年数。
72 2
JavaScript基础知识-流程控制之while循环
|
2月前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
7月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的销售项目流程化管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的销售项目流程化管理系统附带文章源码部署视频讲解等
78 3
|
4月前
|
JavaScript 前端开发
JavaScript基础知识-流程控制之for循环
这篇文章讲解了JavaScript中的for循环的基础知识,并通过一个实例演示了如何使用for循环来找出所有的三位水仙花数。
66 6
JavaScript基础知识-流程控制之for循环
|
5月前
|
JavaScript
js渲染乘法表
js渲染乘法表
36 1
|
5月前
|
大数据 数据处理 分布式计算
JSF 逆袭大数据江湖!看前端框架如何挑战数据处理极限?揭秘这场技术与勇气的较量!
【8月更文挑战第31天】在信息爆炸时代,大数据已成为企业和政府决策的关键。JavaServer Faces(JSF)作为标准的 Java Web 框架,如何与大数据技术结合,高效处理大规模数据集?本文探讨大数据的挑战与机遇,介绍 JSF 与 Hadoop、Apache Spark 等技术的融合,展示其实现高效数据存储和处理的潜力,并提供示例代码,助您构建强大的大数据系统。
71 0