js中的分支与循环
一、js的分支结构
js的分支结构包括:if-else结构、多重if结构、嵌套if结构和switch-case结构
1、if-else结构
1、结构的写法:
if(判断条件){
//条件为ture时,执行if的{}
}else{
//条件为false时,执行else的{}
}
2、注意事项:
①else{}语句块。可以根据情况进行省略。
②if和else后面的{}可以省略,但是省略{}后,if和else后面只能跟一条语句;(所以,并不建议省略{})
3、if的()中的判断条件,支持的情况:
①Boolean:ture为真,false为假;
②String:空字符串为假,所有非空字符串为真;
③Number:0为假,一切非0数字为真;
④Null/undefined/NaN:全为假;
⑤Object:全为真;
示例:要求:如过三件商品的总价大于100元或折其中一件商品的价格大于50元,则打8.5折。
var num1 = parseFloat(prompt("请输入第一种商品的价格:"));
var num2 = parseFloat(prompt("请输入第二种商品的价格:"));
var num3 = parseFloat(prompt("请输入第三种商品的价格:"));
if(num1>50||num2>50||num3 > 50||(num1+num2+num3)>100){
var mon = (num1+num2+num3)*0.85;
alert("总价为:"+mon);
}else{
var mon = (num1+num2+num3);
alert("总价为:"+mon);
}
2、多重if结构
1、结构写法:
if(条件一){
//条件一成立,执行的操作
}else if(条件二){
//条件一不成立&&条件二成立,执行的操作
}else{
//上述条件都不成立执行的操作
}
2、多重if结构中,各个判断条件是互斥的,执行选择其中一条路执行。遇到正确选项并执行完以后,直接跳出结构,不再判断后续分支;
示例:根据成绩计算成绩等级
var m = prompt("请输入成绩:");
if(m >=90){
alert("优");
}else if(m >=80&&m <90){
alert("良");
}else if(m>=60&&m<80){
alert("中");
}else{
alert("差");
}
3、嵌套if结构
1、结构写法:
if(条件一){
//条件一成立
if(条件二){
//条件一成立&&条件二成立
}else {
//条件一成立&&条件二不成立
}
}else{
//条件一不成立
}
2、在嵌套if结构中,如果省略{},则else结构永远属于离他最近的一个if结构。
3、嵌套结构可以多层嵌套,但是一般不超过3层。能用多层if结构的一般不推荐使用嵌套if。
示例:输入三个数并求出三个数的最大值
<script type="text/javascript">
var a= prompt("请输入第一个数:");
var b= prompt("请输入第二个数:");
var c= prompt("请输入第三个数:"); if(a>b){
if(a>c){
alert("最大值为:"+a);
}else {
alert("最大值为:"+c);
}
}else {
if(b>c){
alert("最大值为:"+b)
}else {
alert("最大值为:"+c)
}
} </script>
4、switch-case结构
1、结构写法:
switch(表达式){
case 值1 : 语句1 break;
case 值2 : 语句2 break;
...
default : 语句n break;
}
2、注意事项:
①switch结构()中的表达式可以使用各种js支持的数据类型;
②switch结构在进行判断的时候,使用===(全等)判断;
③case后面的表达式可以是各种数据类型,但是值要求各不相同,否则也只会执行第一个case;
④break作用:执行完case后,跳出当前switch结构;
缺少break后果:从第一个正确的case项开始,执行后面的所有case和default;
原因:↓
⑤switch结构在进行判断的时候,只会判断一次正确答案。当遇到正确的case后,将不会在判断后续的项目。
⑥switch结构的执行效率要比多重if快。在多路分支结构中,优先推荐使用switch。
示例:
var num=5;
switch (num-4){
case 1:
document.write("第一个case");
break;
case 2:
document.write("第二个case");
break;
case 3:
document.write("第三个case");
break;
default:
document.write("case都不成立,执行default");
break;
}
二、循环结构
常用的循环结构有:while循环、do-while循环,for循环和循环的嵌套;
其中,循环结构的步骤:1、声明循环变量; 2、判断循环条件3、执行循环体操作;4、更新循环变量;
然后循环执行2-4,知道条件不成立时,跳出循环。
1、while循环:
1、结构:
var num=1; //1、声明循环变量
while(num <10){ //2、判断循环条件
document.write(num+"<br>"); //3、执行循环体操作;
num++;
}
2、注意事项:
①while循环中的表达式可以是各种类型。但是最终都会转为真假,转换规则同if相同:
②while循环的特点:先判断再执行;
示例:输入一个数字,计算1到这个数字所有数字的和;
var num = parseInt(prompt("请输入一个数字"));
var i = 1 ;
var sum=0;
while (i<=num){
sum+=i;
i++;
}
2、do-while循环
1、结构:
do{
语句
}while(判断条件);
2、注意事项:
do-whlie循环的特点:先执行,再判断;即使初始条件不成立,do-while循环也至少执行一次。
示例:猜数游戏。要求猜一个介于1~10之间的数字,根据用户猜测的数与标准值进行对比,并给出提示,以便下次猜测能接近标准值,直到猜中为止。
var a = 7;
do{
var b = prompt("请输入一个数:");
if(b>7) {
alert("数字太大了~");
}else if(b<) {
alert("数字太小了~");
}else {
alert("你真聪明!猜对了!")
}
}while(b!=a);
3、for循环
1、结构
for(var i=1;i<10;i++){
语句;
}
2、for循环有三个表达式:
申明循环变量
判断循环条件
更新循环变量
三个表达式之间用分号分隔,三个表达式可以省略,但是两个分号缺一不可。
3、for循环执行特点:先判断,再执行,与while相同。
4、 for循环三个表达式都可以有多部分组成;第二部分多个判断条件用&& ||链接,第一三部分用逗号分隔;
示例:计算1到100之间所有数字的和:
<script type="text/javascript">
var sum=0;
for(var a=1,b=100;a<=50&&b>=51;a++,b--){
if(b==51) {
document.write("("+a+"+")
document.write(b+")=");
}else {
document.write("("+a+"+") document.write(b+")+");
}
var sum = sum+parseInt(a+b);
}
document.write(sum);
</script>
4、循环嵌套:
1、循环嵌套的规律
外层循环控制行数,内层循环控制每行中元素的个数。
示例:打印九九乘法表:
<script type="text/javascript">
var sum=0;
for (var i = 1;i<=9;i++) { document.write("<table border=2;>")
var rowSum=1;
document.write("</tr>")
for(var j=1;j<=i;j++){ sum = i*j;
document.write("<td >"+i+"*"+j+"="+sum+"</td>");
}
document.write("</tr>") document.write("</table>")
} </script>
4、循环控制语句
1、break:跳出本层循环,继续执行循环后面的语句。
如果循环有多层嵌套,则break只能跳出一层;
2、continue:跳过本层循环剩余的代码,继续执行下一次循环。
①对于for循环,continue之后执行的代码,是循环变量更新语句,i++;
② 对于while、do-while循环,continue之后执行的语句,是循环条件判断;
因此,使用这两个循环时,必须将continue放到i++之后使用。否则continue跳过i++导致死循环。
js中的分支与循环的更多相关文章
- JavaScript 基础——使用js的三种方式,js中的变量,js中的输出语句,js中的运算符;js中的分支结构
JavaScript 1.是什么:基于浏览器 基于(面向)对象 事件驱动 脚本语言 2.作用:表单验证,减轻服务器压力 添加野面动画效果 动态更改页面内容 Ajax网络请求 () 3.组成部分:ECM ...
- JS中的运算符和JS中的分支结构
JS中的运算符 1.算术运算(单目运算符) + .-.*. /. %取余.++自增 .--自减 +:两种作用,链接字符串/加法运算.当+两边全为数字时,进行加法运算:当+两边有任意一边为字符串时,起链 ...
- 一文搞懂 js 中的各种 for 循环的不同之处
一文搞懂 js 中的各种 for 循环的不同之处 See the Pen for...in vs for...of by xgqfrms (@xgqfrms) on CodePen. for &quo ...
- js中奇特的for循环写法
//正常的for循环 for(var i=0;i<10;i++){ console.log(i); } //输出:1,2,3……10 //简写 for(var i=10;i--;){ conso ...
- JS中的分支结构
if语句 语法: if (expression1) { } else if (expression2) { } else { } 执行机制: 先对expression1做判定,如果为真,执行对应的代码 ...
- JS基础-----JS中的分支结构及循环结构
[分支结构] 一.if-else结构 1.结构的写法:if(判断条件){ //条件为true时,执行if的{} }else{ //条件为false时,执行else的{} } 2.注意事项 ①else语 ...
- JS中有关分支结构、循环结构以及函数应用的一些简单练习
案例一:搬桌子 年龄大于七岁男女都可以搬桌子,年龄小于七岁大于五岁的男生可以搬桌子: var num =parseInt(prompt("请输入你的年龄")) var sex ...
- oracle中的分支与循环语句
分支语句 if的三种写法一, if 2 < 1 then dbms_output.put_line('条件成立'); end if; 二, if 2 < 1 then dbms_outpu ...
- js中数组以及for循环的使用
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> < ...
随机推荐
- Oracle强制启动和关闭实例
要启动和关闭数据库,必须要以具有Oracle 管理员权限的用户登陆,通常也就是以具有SYSDBA权限的用户登陆.一般我们常用SYS用户以SYSDBA连接来启动和关闭数据库.下面介绍Oracle数据库几 ...
- 20170721_python字符串操作_《python语言及其应用》
str = 'abcde...wxyz' [num]提取指定字符 str[0] == 'a' str[1] == 'b' str[-1] == 'z' [start:end:step]分片/切片,一定 ...
- hdu_3336: Count the string(KMP dp)
题目链接 题意:求给定字符串中,可以与某一前缀相同的所有子串的数量 做这道题需要明白KMP算法里next[]数组的意义 首先用一数组nex[](这里与之前博客中提到的next明显不同)存储前缀后缀最长 ...
- luogu P1361 小猫爬山 [iddfs]
题目描述 WD和LHX饲养了N只小猫,这天,小猫们要去爬山.经历了千辛万苦,小猫们终于爬上了山顶,但是疲倦的它们再也不想徒步走下山了. WD和LHX只好花钱让它们坐索道下山.索道上的缆车最大承重量为W ...
- 浅谈redux-form在项目中的运用
准则 先说一下redux的使用场景,因为如果没有redux,那更不会有redux-form. redux基于Flux架构思想,是一个状态管理框架,其目标是解决单页面应用中复杂的状态管理问题. 日常前端 ...
- 国内网站遭遇SYN攻击事如何及时解决问题
1.SYN/ACK Flood攻击:这种攻击方法是经典最有效的DDOS方法,可通杀各种系统的网络服 务,主要是通过向受害主机发送大量伪造源IP和源端口的SYN或ACK包,导致主机的缓存资源被耗 尽或忙 ...
- MySql数据库在表中添加新字段,设置主键,设置外键,字段移动位置,以及修改数据库后如何进行部署和维护的总结
1,为当前已有的表添加新的字段 alter table student add studentName varchar(20) not null; 2,为当前已有的表中的字段设置为主键自增 alter ...
- 一个爬取Bing每日壁纸的python脚本
1. 背景 Bing搜索每天的背景图片有些比较适合做桌面,但是有的提供下载有的不提供下载.每天去点击下载又不太方便,所以第一次学习了一下python爬虫怎么写,写的很简单. 2. 相关技术 2.1 P ...
- (转)centos7安装telnet服务
场景:在进行Telnet测试时候,发现无法连接,所以还得把这个软件也安装了 1 CentOS7.0 telnet-server 启动的问题 解决方法: 先检查CentOS7.0是否已经安装以下两个 ...
- Angularjs基础(学习整理)
AngularJS 通过 ng-directives 扩展了 HTML. ng-app 指令定义一个 AngularJS 应用程序. ng-model 指令把元素值(比如输入域的值)绑定到应用程序. ...