表达式语句: 一个表达式可以产生一个值,有可能是运算、函数调用 字面量 表达式可以放在任何需要值的地方。

  语句: 语句可以理解成一个行为,循环语句和判断语句就是典型的语句,一个程序有多个语句组成。

  流程控制的三种结构:  

    顺序结构: 从上到下依次执行
    分支结构: 根据不同的情况,执行对应的代码
    循环结构: 重复做一件事情

一、流程控制

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入门第二篇之流程控制语句的更多相关文章

  1. ElasticSearch入门 第二篇:集群配置

    这是ElasticSearch 2.4 版本系列的第二篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...

  2. [dart学习]第六篇:流程控制语句

    经过前面的基础知识了解学习,我们今天可以进入语句模块啦. dart主要有以下流程控制语句: if-else for循环 while和do-while循环 break和continue switch-c ...

  3. C#入门篇5-7:流程控制语句 continue语句

    #region continue语句 public class ContinueApp { public static void Fun1() { //标签打印显示1…30,若能被3整除则不打印. ; ...

  4. C#入门篇5-8:流程控制语句 break语句

    #region break语句 public class Breakapp { public static void Fun1() { //计算1+2+…+100的求和程序,打印显示每次循环计算的结果 ...

  5. 微信js框架第二篇(创建完整界面布局)

    接着昨天的继续谈关于微信新出的这个js框架,今天主要谈一个页面的创建到布局的详细步骤. 一.创建一个完整页面       页面你可以创建在项目的任何节点,只要你在入口文件正确引入创建该页面的路径就可使 ...

  6. JavaMail入门第二篇 创建邮件

    JavaMail API使用javax.mail.Message类来表示一封邮件,Message类是一个抽象类,所以我们需要使用其子类javax.mail.internet.MimeMessage类来 ...

  7. js基础知识之_流程控制语句

    javascript 流程控制 流程控制:就是程序代码执行顺序 流程控制:通过规定的语句让程序代码有条件的按照一定的方式执行 顺序结构 按照书写顺序来执行,是程序中最基本的流程结构 选择结构(分支结构 ...

  8. Android JNI入门第二篇——Java参数类型与本地参数类型对照

    前面一篇通过简单的例子介绍了android中JNI的使用.这一篇从基础上了解一些Java参数类型与本地参数类型区别. 1)        java中的返回值void和JNI中的void是完全对应的哦! ...

  9. Hadoop入门第二篇-MapReduce学习

    mapreduce是一种计算模型,是google的一篇论文向全世界介绍了MapReduce.MapReduce其实可以可以用多种语言编写Map或Reduce程序,因为hadoop是java写的,所以通 ...

随机推荐

  1. osg机械臂模拟

    实现自由旋转  

  2. 源码安装LNMP

    需要准备的安装包以及下载地址(只是一个大概地址,版本和下载方式需要自行选择): Nginx http://nginx.org/en/download.html nginx主程序包 MySQL http ...

  3. 123457123456#0#-----com.yuming.FromPuzzleGame01--前拼后广--宝宝农场拼图cym

    com.yuming.FromPuzzleGame01--前拼后广--宝宝农场拼图cym

  4. SpringCloud学习成长之路 六 cloud配置中心

    一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件.在Spring Cloud中,有分布式配置中心组件spring cloud config ...

  5. tp5.1 model 方法下的like语句查询

    $where_like = ['title','like','%' . $_GET['title'] . '%']; $result_list = $this->model->where( ...

  6. ADFS RelayState

    https://blogs.technet.microsoft.com/askds/2012/09/27/ad-fs-2-0-relaystate/ 什么是RelayState,我为什么要关心?有两种 ...

  7. Android Monkey压力测试(转)

    参考链接:https://www.cnblogs.com/yyh8/p/6707745.html Monkey 是Android SDK提供的一个命令行工具, 可以简单,方便地运行在任何版本的Andr ...

  8. 【MM系列】在SAP里查看数据的方法

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]在SAP里查看数据的方法   前言部 ...

  9. leetcode1140 Stone Game II

    思路: dp,用记忆化搜索比较好实现. 实现: class Solution { public: int dfs(vector<int>& sum, int cur, int M, ...

  10. 解决Windows7下virtualbox安装ubuntu出现的0x00000000指令引用0x00000000内存,该内存不能为written问题

    公司电脑只能用Windows7,不能用10,也没WSL用,最近想跑个Linux环境,因为之前装docker toolbox装了virtualbox,没道理再装vmware,遂用vbox开始折腾,没想到 ...