流程控制介绍,顺序结构、分支结构、循环结构、Promise对象、throw语句、break和continue关键字

流程控制

流程控制:指代码的执行顺序,有三种方式:顺序结构、分支结构、循环结构
在这里插入图片描述

顺序结构:

代码从上到下,从左到右的执行顺序。

分支语句:

if语句、if-else语句、if-else if-else···语句、switch-case语句、三元表达式:

<script>// if-else语句:// if (条件) {//     要执行的代码1// } else {//     要执行的代码2// };var age = 19;if (age == 19) {console.log('等于19');};var num = prompt('请输入数字');if (num % 2 == 0) {console.log('该数字是偶数');} else {console.log('该数字是奇数');};var result = prompt('请输入B');if (result == 'B') {var result2 = prompt('请输入Y');if (result2 == 'Y') {console.log('您输入的的有效字母是:Y');} else {console.log('您输入的无效字符是:' + result2);};} else {var result3 = prompt('请输入T');if (result3 == 'T') {console.log('您输入的是有效字母:T');} else {console.log('您输入的无效字符是:' + result3);};};var num1 = 40;var num2 = 30;if (num1 > num2) {console.log(num1);} else {console.log(num2);};// 三元表达式: 条件? 表达式1: 表达式2;var age = 18;var result = age >= 18 ? '成年' : '未成年';console.log(result);var result = 5 > 3 ? '对' : '错';console.log(result); //对var num = 2 - 1 > 5 - 6 ? 2 - 1 : 5 - 6;console.log(num); //1var str = 10 - 5 < 0 ? 5 - 5 > 0 ? 'Y' : 'N' : 5 - 5 == 0 ? 'y' : 'n';console.log(str); //y//if-else if-else语句:var score = prompt('请输入分数');if (isNaN(score)) {console.log('输入有误');} else if (score > 90 && score <= 100) {console.log('A级');} else if (score > 80 && score <= 90) {console.log('B级');} else if (score > 70 && score <= 80) {console.log('C级');} else if (score > 0 && score <= 70) {console.log('成绩不合格');} else if (score > 100 || score < 0) {console.log('输入有效成绩');};// switch-case:多分支语句;// 语法:switch(表达式){//     case 值1 :代码1;break;//     case 值2 :代码2;break;//     case 值3 :代码3;break;//     ···//     default:代码4;break;(这里break和default可省略)// }   var score = prompt('请输入ABC等级别');switch (score) {case 'A':console.log('分数在100-90之间');break;case 'B':console.log('分数在80-70之间');break;default:console.log('分数在0-60之间');};//当好几个case有相同的结果时,可以省略重复的代码块,只需要在最后一个case后面跟代码块:var sease = prompt('请输入月份');switch (sease) {case '1':case '2':case '3':console.log('春季');break;case '4':case '5':case '6':console.log('夏季');break;case '7':case '8':case '9':console.log('秋季');break;case '10':case '11':case '12':console.log('冬季');break;};</script>

循环结构:

while循环、do-while循环、for循环、for-in循环、for-of循环:

<script>// while循环语句:先判断条件是否成立,成立执行大括号中的内容,否则不执行大口号中的内容// while(循环条件){//     循环体//     计数器// }// while循环特点:先判断,后循环,有可能一次循环体都不执行var i = 0;while (i < 10) {console.log(i);i++;};var i = 0;var sum = 0;while (i < 100) {sum += i;i++};console.log(sum);var i = 1;sux = 1;while (i <= 3) {sux = sux * i;i++;};console.log(sux);var i = 1;var sum = 0;while (i <= 100) {if (i % 2 == 0) {sum = sum + i;i++;} else {i++;};};console.log(sum);var sum = 0;var i = 1;while (i <= 100) {if (i % 2 != 0) {sum += i;};i++;};console.log(sum);var i = 1;while (i <= 100) {if (i % 7 == 0) {console.log(i);};i++;};var admin = prompt('请输入账号');var keyw = prompt('请输入密码');while (admin != 'admin' || keyw != '123') {admin = prompt('重新输入账号');keyw = prompt('重新输入密码');};console.log('登录成功');//do-while循环语句:先执行一次循环,后判断条件,成立继续循环,不成立就跳出循环。//  do{//      循环体//  }while(条件);// do-while循环特点:先循环,后判断,至少执行一次循环体var i = 0;do {console.log(i);i++;} while (i < 10);do {var yn = prompt('我帅吗?请用Y或者N回答');} while (yn !== 'Y');console.log('谢谢夸奖');var sum = 0;var i = 0;do {if (i % 3 == 0) {sum += i;}i++;} while (i <= 100);console.log(sum);/* for循环语句:先执行一次表达式1,然后判断表达式2;如果不成立则直接跳出循环,如果表达式2成立,执行循环体的代码,结束后,跳到表达式3执行,然后跳到表达式2,判断表达式2是否成立,不成立,则跳出循环,如果表达式2成立,则执行循环体,然后再跳到表达式3,再跳到表达式2,判断是否成立,一直如此 */var sum = 0;for (var i = 1; i <= 100; i++) {sum += i;};console.log(sum);var sum = 0;for (var i = 1; i <= 100; i++) {if (i % 2 == 0) {sum += i;};};console.log(sum);var sum = 0;for (var i = 1; i <= 100; i++) {if (i % 2 == 1) {sum += i;};};console.log(sum);var sum = 0;for (var i = 1; i <= 100; i++) {if (i % 3 == 0) {sum += i;};};console.log(sum);for (var i = 0; i < 6; i++) {for (var j = 0; j <= i; j++) {document.write('*');};document.write('<br>');};// for in循环:用于对数组索引或者对象的属性进行循环操作,语法:// for (变量 in 对象){//     执行的代码// };var obj = {name: '明明',age: '18岁'};for (var i in obj) {console.log(i);};// for-of遍历数组的元素,键值对对象会报错(不遍历某些对象,数组对象是可以遍历的)// for (变量 of 数组){//     执行的代码// };for (var k of arr) {console.log(k); //1  '2'  3  '4'  'str'}for (var k of obj) {console.log(k); //Uncaught TypeError: obj is not iterable at test.html:34};</script>

break和continue关键字:
在这里插入图片描述

 <script>for (var i = 1; i < 100; i++) {if (i % 7 == 0) {console.log(i);//7break;};};for (var i = 1; i < 22; i++) {if (i % 7 == 0) {console.log(i);continue;//7、14、21};};</script>

label语句:

label语句是用来控制break语句从哪个作用域跳出循环,(默认是跳出当前循环,外面的循环是不会被跳出的)label并非关键字,只要是非保留关键字都可以用来做label语句的标识符,如下面案例:

    <script>iFor:for (var i = 0; i < 5; i++) {console.log('i:' + i);jFor:for (var j = 0; j < 5; j++) {console.log('j:' + j);if (j == 3) break iFor; //默认情况下回跳到jFor这里,也就是说i循环5次,每次i循环中j循环4次;当使用label语句后,i循环1次,j循环了4次};};</script>

throw语句:

当运行错误时,使用throw语句抛出一个异常的信息,如:

<script>throw "文件不存在";//控制台输出:test.html:18 Uncaught 文件不存在
</script>

try-catch-finally语句:

如果try代码块中的语句一旦抛出了异常,那么执行流程会立即进入catch 代码块,如果try代码块没有抛出异常,catch代码块就会被跳过。finally 代码块总会紧跟在try和catch代码块之后执行,但会在try和catch代码块之后的其他代码之前执行(三个语句块不一定同时出现,三语句块也可以嵌套在其他三语句中)。

<script>try {// 抛出异常时执行的语句} catch (e) {//无异常时执行的语句} finally {// 抛出异常或无异常时都执行的语句};
</script>

Promise对象:

ECMAScript 6中提供promise对象操作延时和异步的流程控制,Promise 对象有以下几种状态:

  • pending:初始的状态,即正在执行,不处于 fulfilled 或 rejected 状态。
  • fulfilled:成功的完成了操作。
  • rejected:失败,没有完成操作。
  • settled:Promise 处于 fulfilled 或 rejected 二者中的任意一个状态, 不会是 pending。
    在这里插入图片描述
  • settled:Promise 处于 fulfilled 或 rejected 二者中的任意一个状态, 不会是 pending。
<script>// 为了解决回调地狱问题带来的代码不好维护问题,这里可以使用ES6提供的方法:promise,使用步骤如下:// 1.创建promise容器:一旦创建这个容器就会执行里面的代码new Promise(function(resolve, rejecte) {fs.readFile('./data/c.txt', 'utf8', function(err, data) {if (err) {rejecte(err)} else {resolve(data)}});}); //2.在容器中放一个函数并在其中执行异步操作//案例:var p1 = new Promise(function(resolve, reject) {fs.readFile('./data/a.txt', 'utf8', function(err, data) {if (err) {reject(err)} else {resolve(data)}})})var p2 = new Promise(function(resolve, reject) {fs.readFile('./data/b.txt', 'utf8', function(err, data) {if (err) {reject(err)} else {resolve(data)}})})var p3 = new Promise(function(resolve, reject) {fs.readFile('./data/c.txt', 'utf8', function(err, data) {if (err) {reject(err)} else {resolve(data)}})})p1.then(function(data) {console.log(data)// 当 p1 读取成功的时候// 当前函数中 return 的结果就可以在后面的 then 中 function 接收到,当你 return 123 后面就接收到 123,return 'hello' 后面就接收到 'hello',没有 return 后面收到的就是 undefined// 真正有用的是:我们可以 return 一个 Promise 对象,当 return 一个 Promise 对象的时候,后续的 then 中的 方法的第一个参数会作为 p2 的 resolvereturn p2}, function(err) {console.log('读取文件失败了', err)}).then(function(data) {console.log(data)return p3}).then(function(data) {console.log(data)console.log('end')})</script>

提示:本文图片等素材来源于网络,若有侵权,请发邮件至邮箱:810665436@qq.com联系笔者 删除。
笔者:苦海

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575398.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

楼宇对讲门铃的芯片选型分析

目前很多的高层住宅都使用了对讲门铃了&#xff0c;在频繁使用中&#xff0c;门铃会出现的越来越多种类&#xff0c;下面我就简单的介绍会有用到的几款芯片. 语音通话芯片&#xff1a;D34018,D34118,D5020,D31101; D34018 单片电话机通话电路&#xff0c;合并了必 需的放大器…

javascript中内置对象简介、Array

内置对象&#xff1a; javascript的三种对象&#xff1a;1.内置对象—JavaScript自带的对象&#xff1b;2.自定义对象—自己定义构造函数创建对象&#xff1b;3.浏览器对象— BOM时候介绍&#xff0c;几个常用内置对象&#xff1a;Math Date String Array Object Array对象&a…

javascript中Date对象及方法

Date对象&#xff1a; 该对象呈现时间中的某个时刻。其本质是自1970年1月1日&#xff08;UTC&#xff09;起经过的毫秒数&#xff0c;相关属性的方法如下&#xff1a;&#xff08;如果Date对象中传入指定的时间&#xff0c;则以传入的指定时间返回相关数据&#xff0c;就不会以…

JAVA Web学习篇--Servlet

Servlet由来 做过BS项目的人都知道&#xff0c;浏览器可以依据HTML静态标记语言来显示各式各样的网页。可是假设我们须要在网页上完毕一些业务逻辑&#xff1a;比方登陆验证。或者说网页显示的内容在server的数据库中。假设是这样&#xff0c;除了负责显示的HTML标记之外&#…

javascript中Math对象及方法

Math对象&#xff1a; 其所有属性与方法都是静态的&#xff0c;其相关属性和方法如下&#xff1a; 继&#xff1a; 继&#xff1a; 提示&#xff1a;本文图片等素材来源于网络&#xff0c;若有侵权&#xff0c;请发邮件至邮箱&#xff1a;810665436qq.com联系笔者 删除。 笔者…

javascript中NaN属性、null对象、Number对象、Object对象

NaN属性&#xff1a; 表示不是一个数字&#xff0c;是全局对象的属性&#xff0c;其初始值为NaN <script>console.log(NaN NaN); //false</script>null对象&#xff1a; 特指对象的值未设置 <script>console.log(null undefined); //trueconsole.log(nul…

Apache安装、配置、卸载

下载安装配置Apache&#xff1a; 1.将Apache官方下载地址&#xff1a;https://www.apachelounge.com/download/&#xff0c;复制到浏览器打开&#xff0c;选择系统支持的版本下载&#xff0c;如&#xff1a; 2.将下载好的压缩包剪贴到C盘根目录&#xff08;这里为了方便&…

企业级应用架构(一) 三层架构之解耦

前言 前段时间朋友拿了个网站给我&#xff0c;让我帮忙添加几个小功能&#xff0c;我爽快的答应了,但是当我打开源码&#xff0c;我瞬间就奔溃了&#xff0c;整个项目连最基本的三层框架也没有搭建&#xff0c;仅仅是封装了一个sqlhelp作为数据库的操作接口&#xff0c;项目中的…

web api、获取DOM元素的方式、事件理解、click事件在移动端300ms延时、事件对象、事件委托、常见事件类型

web api: API&#xff08;Application Programming Interface&#xff0c;应用程序编程接口&#xff09;是一些预先定义的函数&#xff0c;目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力&#xff0c;而又无需访问源码&#xff0c;无需理解其内部工作机…

transitionend、change、classList、兼容代码、元素样式属性的操作、-Attribute自定义属性、阻止跳转、元素绑定相同事件、元素解绑事件、事件冒泡、事件三阶段

transitionend过渡监听事件&#xff1a; 过渡监听事件transitionend指的是CSS3中过渡效果执行一次后触发事件处理函数&#xff0c;如下案例&#xff1a; <!DOCTYPE html><html><head><meta charset"utf-8"><title></title><…

Unix/Linux环境C编程入门教程(18) kali-linuxCCPP开发环境搭建

1. Kali linux是BT5的晋级版本&#xff0c;用于信息安全。基于Debian7内核。新建虚拟机。2. 选择默认虚拟机3. 选择稍后安装操作系统4.选择Linux Debian7 64位&#xff0c;因为KaliLinux基于Linux Debian7。5. 设置虚拟机名称为KaliLinux6.设置处理器为双核。7. 设置内存为2G8.…

javascript中BOM介绍、屏幕尺寸、历史记录、URL解析、计算机信息获取、定时器、三大系列及兼容代码、封装动画函数、同步和异步

BOM介绍&#xff1a; BOM指的是浏览器对象模型&#xff0c;是用来操作浏览器的&#xff0c;例如浏览器弹窗、地址栏、滚动条等&#xff0c;浏览器顶级对象&#xff1a;window&#xff1b;页面中的所有内容都是属于window的&#xff0c;window可以省略&#xff1b;confirm(‘带…

javascript中实例对象和构造函数关系、原型语法、原型链、call实现继承、apply调用函数、bind拷贝函数、拷贝继承、class类、super、严格模式、高阶函数、闭包、递归、es6简介

实例对象和构造函数的关系及原型&#xff1a; 实例对象是通过构造函数创建出来的&#xff0c;实例对象的构造器constructor就是指向构造函数的&#xff1b;每个实例对象中的同一方法的指向是各不相同的&#xff0c;但是其属性值相同的属性可以相同&#xff0c;这样会造成内存浪…

移动web现状、viewport视口、二倍图、移动web开发主流方案、布局技术选型(流式布局、flex弹性布局、less+rem+媒体查询布局、混合布局、媒体查询、bootstrap)

移动端web现状&#xff1a; 移动端常见浏览器&#xff1a;UC浏览器&#xff0c;QQ浏览器&#xff0c;Opera浏览器&#xff0c;百度手机浏览器&#xff0c;360安全浏览器&#xff0c;谷歌浏览器&#xff0c;搜狗手机浏览器&#xff0c;猎豹浏览器及杂牌浏览器。移动端常见的浏览…

jQuery中事件及常用事件总结、jQuery中常见效果、隐式迭代、链式编程、样式操作、动画队列、不同元素绑定同一个事件

jQuery事件&#xff1a; jQuery中的事件和javascript中的事件基本相似&#xff0c;不同的是jQuery中的事件处理函数写在事件后面的括号中&#xff0c;如&#xff1a; <script>$(input).click(function() {alert(hello word);});</script>jQuery中常见事件&#xf…

BigQuery 分区表简介和使用

大纲 什么是分区表 我们先看定义&#xff1a; 分区表是一种数据库表设计和管理技术&#xff0c;它将表中的数据划分为逻辑上的多个分区&#xff0c;每个分区包含一组特定的数据。每个分区都根据定义的分区键&#xff08;通常是一个列或字段&#xff09;的值进行分类&#xff…

jQuery操作属性、设置文本、遍历元素、元素创建添加删除、操作元素尺寸、操作元素位置、注册事件、事件处理、解绑事件、拷贝、多库共存、jQuery插件

jQuery操作属性&#xff1a; jQuery中提供三种方法操作属性&#xff0c;分别是&#xff1a;prop()、arrt()、data(),具体如下&#xff1a; prop()操作自带属性&#xff1a;用来操作元素本身自带的属性&#xff08;包括没有显示在DOM上的自带属性&#xff09;&#xff0c;如:a…

分享MYSQL中的各种高可用技术(源自姜承尧大牛)

图片和资料来源于MYSQL大牛姜承尧老师&#xff08;MYSQL技术内幕作者&#xff09; 姜承尧&#xff1a; 网易杭州研究院 技术经理 主导INNOSQL的开发 mysql高可用各个技术的比较 数据库的可靠指的是数据可靠 数据库可用指的是数据库服务可用 可靠的是数据&#xff1a;例如工商银…

数据库、MySQL介绍及安装流程、SQL语句中增删改查、SQL注入、通过php操作数据库,plugin ‘caching_sha2_password加密规则,分表查询

MySQL数据库&#xff1a; 数据库&#xff1a; 存放数据的仓库&#xff0c;用来按照特定的结构去组织和管理我们的数据&#xff0c;有数据库就可以更加方便的储存数据&#xff1b; 数据库只是存储数据的一种手段&#xff0c;最终数据是存放在硬盘中的&#xff0c;只是存放的格…

chartjs和echartsjs库简介

chart.js和echarts.js: 尽管我们已经掌握了canvas绘图和SVG矢量图&#xff0c;在实际开发中我们依旧不会使用canvas和SVG&#xff0c;因为考虑到开发成本&#xff0c;一般会采用相关的图表库进行辅助开发&#xff0c;市面上常用的图表库有chart.js和echarts.js&#xff1b;如果…