学习 JavaScript (五)核心概念:语句
语句
语句被称作是流控制语句,通常有标志性的一个或者多个关键字,if 、 do-while、 while、for、 for-in、 label、 break、continue、with、switch。
if 语句
if 语句就是我们常说的条件语句,在条件满足的情况下,执行一段代码,条件不满足就不执行,if...else...。
if ('条件'){
代码块 1
}else{
代码块 2
}
看下面的示例:
if (i>25){
alert ('i 大于 25')
} else {
alert ('i 小于或等于 25')
}
代码块可以不用 {} 包着,但是使用会让代码更清晰。也可以增加多个条件, if...else if...else...:
if (i>25){
alert('i 大于 25')
} else if(i=25) {
alert('i 等于 25')
} else {
alert('i 小于 25')
}
do-while 语句
do-while 语句是一种后测试循环语句,也就是说,不管条件成不成立,先执行一遍代码。形式如下:
do {
代码块 // 这里的代码肯定会被执行一次
} while (条件)
while 语句
while 语句是一种前测试循环语句,这个语句的用法和 if 一致,先判断条件再执行代码。
while(条件){
代码块;// 只有条件满足才会被执行
}
for 语句
for 语句也是一个前测试循环语句,在循环执行之前初始化变量和定义循环后要执行的代码的能力。比如:
for(初始化变量;约束条件;后置操作符){
代码块
}
// 举一个例子
for(let i = 0; i < 10; i++){
alert(i)
}
三个表达式都是可以选的,如果全部为空则代码块部分会无限循环下去。
for-in
for-in 语句是一种精准的迭代语句,一个典型的用法就是枚举对象的属性。比如:
for (let item in object){
代码块
}
其中 let 可以省略,写上会好一些。
label 语句
label 的作用就是给代码做一个标记,一遍我们在接下来的代码中引用,经常和 for 循环语句联合使用,下面会有示例。比如:
start: for(let i = 0; i < 10; i++){
alert(i)
}
break 和 continue 语句
按照我自己的理解,break 语句会让代码中途彻底退出,请看示例:
let a = 0;
for (let i = 1; i < 10; i++){
if(i % 5 == 0){
break;
}
a++;
}
alert(a); // 结果是 4
i 的初始值为 1 ,在 i == 5 的时候,程序跳出循环,执行 alert()
continue 会让代码跳过满足条件的那一次循环,示例在这儿:
let a = 0;
for (let i = 1; i < 10; i++){
if(i % 5 == 0){
continue;
}
a++;
}
alert(a); // 结果是 8
i 的初始值为 1 ,在 i == 5 和 i == 10 的时候,程序各跳出循环一次,所以结果是 8
和 label 语句连用的时候可以改变循环的次数,一般是在嵌套循环中使用的,其中和 break 连用可以穿透多层循环,和 continue 连用只能穿透内层循环。
let a = 0;
outer:for (let i = 0; i < 10; i++){
for (let j = 0; i < 10; j++){
if (i == 5 && j == 5){
break outer;
}
a++;
}
}
alert(a); // 55
当 i == 0,1,2,3,4, j 从 0 执行到 9;
当 i == 5,j 从 0 执行到 4
随后两个循环停止
如果 label 语句遇到 continue ,则是这样:
let a = 0;
outer:for (let i = 0; i < 10; i++){
for (let j = 0; i < 10; j++){
if (i == 5 && j == 5){
continue outer;
}
a++;
}
}
alert(a); // 95
当 j == 5 ,最里面的循环停止一次,外层的循环继续执行。所以,i 能从 0 执行到 9。
with 语句
不经常使用这个语句,严格模式下不被允许使用,大型应用的时候不建议使用。
switch 语句
switch 的语法和 C 语言的语法类似,如下所示:
switch (表达式){
case value :
代码块;
break;
case value :
代码块;
break;
case value :
代码块;
break;
case value :
代码块;
break;
default:
代码块;
}
上面代码的含义就是如果表达式的值是其中一个 case,就执行相应的代码块。如果所有 case 的 value 都不满足要求,则执行 default 下面的代码块。
switch (i){
case 1 :
alert(i);
break;
case 2 :
alert(i);
break;
case 3 :
alert(i);
break;
default:
alert(i);
}
可以看得出来,switch 语句就是 if...else if...else 的简写。
如果不写 break 语句,就是合并两个 case,此时尽量做好注释,说明这不是一个低级错误。
在 JavaScript 中 switch 有一个比较有重要的特性: case 的值不一定是产量,可以是变量,甚至是表达式。这也是其他语言所不具备的:
let a = 25;
switch (true){
case a < 0 :
alert("a 小于 0");
break;
case a > 0 :
alert("a 大于 0");
break;
case a == 0 :
alert("a 等于 0");
break;
default:
alert("a 不是实数");
}
这里 case 返回的是布尔值,返回的是 true 则执行相应的代码块。
注意,switch 比较值的过程中是严格比较,即数字字符串和数字不相等。
欢迎大家关注微信公众号:** 可视化技术( visteacher )**
不仅有前端和可视化,还有算法、源码分析、书籍相送
各个分享平台的 KurryLuo 都是在下。
用心学习,认真生活,努力工作!
学习 JavaScript (五)核心概念:语句的更多相关文章
- Go语言学习笔记五: 条件语句
Go语言学习笔记五: 条件语句 if语句 if 布尔表达式 { /* 在布尔表达式为 true 时执行 */ } 竟然没有括号,和python很像.但是有大括号,与python又不一样. 例子: pa ...
- 使用Firebug或chrome-devToolBar深入学习javascript语言核心
使用Firebug和chrome-devToolBar调试页面样式或脚本是前端开发每天必做之事.这个开发神器到底能给我们带来哪些更神奇的帮助呢?这几天看的一些资料中给了我启发,能不通过Firebug和 ...
- webpack学习2.3webpack核心概念
核心概念(四个) Entry(入口) Output(出口) Loaders()来处理其他类型的资源文件 Plugins(插件) 1.入口(Entry) 作用:代码的入口,打包的入口,单个或多个, 示例 ...
- Elasticsearch学习之基本核心概念
在Elasticsearch中有许多术语和概念 1. 核心概念 Elasticsearch集群可以包含多个索引(indices)(数据库),每一个索引可以包含多个类型(types)(表),每一个类型包 ...
- Docker 学习笔记之 核心概念
Docker核心概念: Docker Daemon Docker Container Docker Registry Docker Client 通过rest API 和Docker Daemon进程 ...
- Python 学习 第五篇:语句和语法
Python程序是语句构成的,语句包含表达式,表达式嵌套在语句中,包含变量和常量,用于处理对象.Python的语法实质上是由表达式.语句和代码块构成的.语句是由表达式构成的,代码块是由多个语句构成的复 ...
- 学习 JavaScript (四)核心概念:操作符
JavaScript 的核心概念主要由语法.变量.数据类型.操作符.语句.函数组成,前面三个上一篇文章已经讲解完了.后面三个内容超级多,这篇文章主要讲解的是操作符. 操作符 什么叫做操作符? 这是一种 ...
- 学习 JavaScript (三)核心概念:语法、变量、数据类型
JavaScript 的核心概念主要由语法.变量.数据类型.操作符.语句.函数组成,这篇文章主要讲解的是前面三个,后面三个下一篇文章再讲解. 01 语法 熟悉 JavaScript 历史的人应该都知道 ...
- 如何正确学习JavaScript
不要这样学习JavaScript 不要一开始就埋头在成堆的JavaScript在线教程里 ,这是最糟糕的学习方法.或许在看过无数个教程后会有点成效,但这样不分层次结构地学习一个东西实在是十分低效,在实 ...
- 「译」如何正确学习JavaScript
原文:How to Learn JavaScript Properly 目录 不要这样学习JavaScript 本课程资源 1-2周(简介,数据类型,表达式和操作符) 3~4周(对象,数组,函数,DO ...
随机推荐
- RabbitMQ在windows系统安装部署文档
1.RabbitMQ简介 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它 ...
- Flask入门之触发器,事件,数据迁移
SQLAlchemy Core和SQLAlchemy ORM都具有各种各样的事件挂钩: 核心事件 - 这些在 Core Events中描述,并包括特定于连接池生命周期,SQL语句执行,事务生命周期以及 ...
- 利用Swagger2自动生成对外接口的文档
一直以来做对外的接口文档都比较原始,基本上都是手写的文档传来传去,最近发现了一个新玩具,可以在接口上省去不少麻烦. swagger是一款方便展示的API文档框架.它可以将接口的类型最全面的展示给对方开 ...
- 怎么解决你的小程序有“bug”的问题?
为了避免小程序在开发运行之后出现"bug"无法知晓,Fundebug研发的小程序bug监控服务作为小程序的运维中心,很好的解决了这个问题. 该插件可以监控小程序中的所有函数调用: ...
- Unity3D学习(六):《Unity Shader入门精要》——Unity的基础光照
前言 光学中,我们是用辐射度来量化光. 光照按照不同的散射方向分为:漫反射(diffuse)和高光反射(specular).高光反射描述物体是如何反射光线的,漫反射则表示有多少光线会被折射.吸收和散射 ...
- mysql中如何处理字符
concat函数 使用方法: CONCAT(str1,str2,…) 返回结果为连接参数产生的字符串.如有任何一个参数为NULL ,则返回值为 NULL. 注意: 如果所有参数均为非二进制字符串,则结 ...
- Go笔记之一:工程项目结构的注意事项
Go笔记之一:工程项目结构的注意事项 对 Go 项目目录的理解 (Windows平台为例) 刚安装完的 Go 需要设定环境变量,最关键的环境变量有三个,GOROOT.GOPATH和GOBIN.GORO ...
- Linux时间子系统之(十三):Tick Device layer综述
专题文档汇总目录 Notes:从概念层次描述了tick-comm.oneshot tick.broadcast tick:重点介绍了tick和tickless概念及其区别,两种tick device: ...
- 报错 'dict' object has no attribute 'has_key'
has_key方法在python2中是可以使用的,在python3中删除了. 比如: if dict.has_key(word): 改为: if word in dict:
- 你不知道的JavaScript--Item18 JScript的Bug与内存管理
1.JScript的Bug IE的ECMAScript实现JScript严重混淆了命名函数表达式,搞得现很多人都出来反对命名函数表达式,而且即便是现在还一直在用的一版(IE8中使用的5.8版)仍然存在 ...