js入门第二篇之流程控制语句
表达式语句: 一个表达式可以产生一个值,有可能是运算、函数调用 字面量 表达式可以放在任何需要值的地方。
语句: 语句可以理解成一个行为,循环语句和判断语句就是典型的语句,一个程序有多个语句组成。
流程控制的三种结构:
顺序结构: 从上到下依次执行
分支结构: 根据不同的情况,执行对应的代码
循环结构: 重复做一件事情
一、流程控制
1. if语法
if 语句
if (条件表达式) {
执行语句;
}
if (条件表达式) {
成立执行语句;
} else {
否则执行语句;
}
if (条件表达式1) {
成立执行语句;
} else if (条件表达式2) {
成立执行语句2;
} else {
最后默认执行语句;
} 三元运算符
1. 表达式1 ? 表达式2 : 表达式3
var num1 = 13;
var num2 = 4;
console.log(num1 > num2 ? num1 : num2);
2. 分支结构switch
判断输入的表达式和值是否是相等 (这里判断的是三个等)
switch (表达式) {
case 常量1:
语句;
break;
case 常量2:
语句;
break;
...
case 常量n:
语句;
break:
defalut:
语句;
}
switch小案例
var day = 5;
switch (day) {
case '1':
console.log('Monday');
break
case '2':
console.log('Turseday');
break;
default:
console.log('What are you doing');
}
二、 循环结构
1. while 语法
1. 当循环条件为true 执行循环
2. 当循环条件为false 结束循环
while (循环条件) {
循环体
}
var i = 1;
while (i <= 100) {
console.log(i);
i++
}
do while 和while的区别
while: 先判断条件 在执行语句 如果条件满足就执行
do while: 先执行语句 在判断条件 条件满足执行语句1 否则执行2
2. do while语法
do {
循环体;
} while (循环条件);
do while案例
rompt 让用户交互输入的 相当于python里面的input
do {
var msg = prompt('你到底爱不爱我? ', '请输入yes/no');
} while (msg !== 'yes');
console.log('哈哈哈')
3. for 循环
for循环的表达式之间用;分号隔开
for (初始化表达式1; 条件表达式2; 自增表达式) {
循环体
}
while和do while 一般用来解决无法确认次数的循环
for 用于能确定循环次数的情况 比较方便
for表达式可以省略 分号不能省略
案例1: 打印三角形
var str = '';
for (var i =0; i<10; i++) {
for (var j =i; j<10; j++) {
str = str + '* ';
}
str = str + '\n';
}
console.log(str);
案例2: 打印正方形
var str = '';
for (var j =0; j<10; j++) {
for (var i = 0; i<10; i++) {
str = str +'* '; }
str = str + '\n';
}
console.log(str);
案例3: 打印九九乘法表
var str = '';
for (var i =1; i <= 9; i++) {
for (j=i; j<=9; j++) {
str += i + '*' + j + '=' + i*j + '\t';
}
str = str + '\n';
}
console.log(str) break 打破循环
for (var i =50; i<=200; i++) {
if (i % 7 === 0) {
console.log(i);
break;
}
}
三、continue和break
1. continue 结束当次循环 继续下一次
var sum = 0;
for (var i=1; i<=100; i++) {
if (i%10 === 3) {
console.log(i);
continue; }
sum += i;
}
console.log(sum);
斐波那契数列例子:
var n1 =1;
var n2 = 1;
var n3;
for (var i = 3; i <=12; i++) {
n3 = n2 + n1;
n1 = n2;
n2 = n3;
}
console.log(n3);
调试debug
调式debug
调试的目的是确定错误的原因和位置,并解决错误
错误
语法错误
逻辑错误
过去调试js的方式
alert()
console.log()
断点调试
浏览器中按F12 --> source 找到需要调试的文件 --> 在程序的某一行设置断点
break待补充......
js入门第二篇之流程控制语句的更多相关文章
- ElasticSearch入门 第二篇:集群配置
这是ElasticSearch 2.4 版本系列的第二篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...
- [dart学习]第六篇:流程控制语句
经过前面的基础知识了解学习,我们今天可以进入语句模块啦. dart主要有以下流程控制语句: if-else for循环 while和do-while循环 break和continue switch-c ...
- C#入门篇5-7:流程控制语句 continue语句
#region continue语句 public class ContinueApp { public static void Fun1() { //标签打印显示1…30,若能被3整除则不打印. ; ...
- C#入门篇5-8:流程控制语句 break语句
#region break语句 public class Breakapp { public static void Fun1() { //计算1+2+…+100的求和程序,打印显示每次循环计算的结果 ...
- 微信js框架第二篇(创建完整界面布局)
接着昨天的继续谈关于微信新出的这个js框架,今天主要谈一个页面的创建到布局的详细步骤. 一.创建一个完整页面 页面你可以创建在项目的任何节点,只要你在入口文件正确引入创建该页面的路径就可使 ...
- JavaMail入门第二篇 创建邮件
JavaMail API使用javax.mail.Message类来表示一封邮件,Message类是一个抽象类,所以我们需要使用其子类javax.mail.internet.MimeMessage类来 ...
- js基础知识之_流程控制语句
javascript 流程控制 流程控制:就是程序代码执行顺序 流程控制:通过规定的语句让程序代码有条件的按照一定的方式执行 顺序结构 按照书写顺序来执行,是程序中最基本的流程结构 选择结构(分支结构 ...
- Android JNI入门第二篇——Java参数类型与本地参数类型对照
前面一篇通过简单的例子介绍了android中JNI的使用.这一篇从基础上了解一些Java参数类型与本地参数类型区别. 1) java中的返回值void和JNI中的void是完全对应的哦! ...
- Hadoop入门第二篇-MapReduce学习
mapreduce是一种计算模型,是google的一篇论文向全世界介绍了MapReduce.MapReduce其实可以可以用多种语言编写Map或Reduce程序,因为hadoop是java写的,所以通 ...
随机推荐
- OVS+VXLAN实现两个宿主机上的VM间的通信
一.组网图 说明: 1.使用网络命名空间表示vm1和vm2. 因为我没有两台物理服务器. 2.使用virtualbox 的两条虚机模拟作为host1和host2. 二.配置指导 1.创建网桥 br0 ...
- QML加载gif
AnimatedImage { anchors.fill: parent source: "qrc:/img/timg.gif" }
- mariadb升级
官方文档升级:https://mariadb.com/kb/en/library/upgrading/ 1.备份原来的数据库和配置文件 # mysqldump -u root -p -A > a ...
- C# using语句 中间出现exception后 using仍然会dispose
C# using语句,中间出现exception后,using仍然会dispose,因为: using语句 相当于 try-finally{dispose()}
- Spring Cloud(7.2):配置Producer Server
我们首先创建一个生产者服务.这里以一个商品价格服务为例,这个微服务可以对商品-价格信息进行增删改查,当有商品-价格信息被更新或删除,则该微服务发送消息,告诉其他调用它的系统这条信息已经被修改. 配置p ...
- Linux下批量解压.Z格式文件
下面的代码演示如何将当前目录下sj目录下的所有.Z格式文件解压到sj_result目录下. 代码示例: for file in `ls ./sj` do prefix=${file%.*} echo ...
- iOS-UIToolbar与UISearchBar
组件_ UIToolbar /** 1. 顶部toolbar 2. TextField可以以UIBarButtonItem的自定义视图的方式加入toolbar 3. 三个按钮 4. 将UIBarBu ...
- Andrew Ng机器学习课程16
Andrew Ng机器学习课程16 声明:引用请注明出处http://blog.csdn.net/lg1259156776/ 说明:主要介绍了ICA算法,并利用最大似然估计和随机梯度上升算法进行求解, ...
- subplot()一个窗口画多个图
import matplotlib.pyplot as plt plt.subplot(m,n,p) m,n表示一个窗口上显示m行n列 p表示正在处理第p个区域的部分(区域编号从左到右,从上到下) f ...
- RISC-V汇编指南
原文出处:https://github.com/riscv/riscv-asm-manual/blob/master/riscv-asm.md RISC-V Assembly Programmer's ...