2018-11-29

17js流程控制switch

<!DOCTYPE html>

<html>

<head>

<title>17js流程控制switch</title>

<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

</head>

<body>

</body>

<script>

//js流程控制switch

/*格式:

switch(条件){

case 1:

语句1;

break;

case 2:

语句2;

break;

case n:

语句n;

break;

defaul:

其他情况;

break;

}

*/

var num = 3;

switch (num){

case 1:

document.write("壹");

break;

case 2:

document.write("贰");

break;

case 3:

document.write("叁");

break;

case 4:

document.write("肆");

break;

default:

document.write("捌");

break;

}

/*注意事项

case是一定要全等于。case 值 === JavaScript 中case判断是否相等时是全等于(===),而不是等于(==)。

也就是说既会判断类型是否相等又会判断值是否相等。

*/

var str = "1";

switch (str){

case 1: //为什么不是这里。

document.write("<br/>我是壹");

break;

case 2:

document.write("<br/>我是贰");

break;

default: //因为一个是数字一个是字符串所以不能是第一个。switch一定要全等于。

document.write("<br/>我是其他的数");

break;

}

var str = "123";

switch(str){

case 123:

document.write("<br/>我是数字123");

break;

case "123":

document.write("<br/>我是字符串123");

break;

default:

document.write("<br/>我是其他的数字");

break;

}

// case 后可以是常量和变量。

var str = 123;

var num = 123;

var str1 = "123";

switch(str){

case num:

document.write("<br/>我是数字123");

break;

case str1:

document.write("<br/>我是字符串123");

break;

default:

document.write("<br/>我是其他的数字");

break;

}

//表达式判断问题  判断时会先计算表达式的值,再判断。

var str = 123 + 10;

var num = 123;

var str1 = "123";

switch(str){

case 10 + 123:

document.write("<br/>我是数字10+123");

break;

case "123 + 10":

document.write("<br/>我是字符串123+10");

break;

default:

document.write("<br/>我是其他的数字");

break;

}

/*case 的穿透问题。

switch里面的case只要匹配一次其它的都会失效,包括default.

在case语句最后增加break语句,使每一次执行之后均可跳出switch语句,从而避免输出不应有的结果。

*/

var str = "123";

switch(str){

case 123:

document.write("<br/>我是数字123");

break;

case "123":

document.write("<br/>我是字符串123");//缺少了break;就会继续执行。下面的把结果全部输出。

default:

document.write("<br/>我是其他的数字<br/>");

break;

}

//default 的位置问题

var str = "123";

switch(str){

case 123:

document.write("<br/>我是数字123");

break;

default:

document.write("<br/>我是其他的数字");

break;

case "1231":

document.write("<br/>我是字符串123");//缺少了break;就会继续执行。下面的把结果全部输出。

break;

}

</script>

</html>

18js流程控制if和switch的转换

<!DOCTYPE html>

<html>

<head>

<title>18js流程控制if和switch的转换</title>

<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

</head>

<body>

</body>

<script type="text/html">

/*js流程控制if 和switch 的转换

题目:

利用if实现

利用switch实现

*/

//要求用户输入一个分数,根据输入的分数输出对应的等级。A:90-100;B:80-89;C:70-79;D:60-69,E:0-59

//1、if

/*//1.1、定义变量,契文存放分数。

var score;

//1.2、提示用户输入分数

score = Number(prompt("请输入0-100之间的分数","0"));

//1.3、根据分数判断等级

if((0<score)&&(100<score)){

alert("你输入有误,请重新输入0-100之间的分数\n");

}else if((90<=score)&&(100>=score)){

document.write("你的分数是A");

}else if((80<=score)&&(89>=score)){

document.write("你的分数是B");

}else if((70<=score)&&(79>=score)){

document.write("你的分数是C");

}else if((60<=score)&&(69>=score)){

document.write("你的分数是D");

}else{

document.write("你的分数是E");

}

//js流程控制if 和switch 的选择

*/

/*

//获取用户输入的信息

var score = prompt("请输入一个分数");

var result;

//针对用户的不同操作,进行相应的数据过滤

if(score == ""){

    alert("对不起,你没有输入任何分数!");

}else if(score == null){

    alert("你已经取消操作了");

}else if(Number(score)!=score) {

//判断输入的不是数值

    alert("对不起,必须输入数值的分数");

}else if(score>100 || score<0){

   alert("对不起,你输入的分数必须介于0-100之间");

}else{

//根据用户不同的分数,来输出不同的评语

if(score>=90){

     result = "优秀";

}else if(score>=80){

     result = "良好";

}else if(score>=70){

     result = "中等";

}else if(score>=60){

     result = "及格";

}else{

     result = "不及格";

}

}

    document.write(result);

*/

//2、switch

//2.1、定义变量,契文存放分数。

var score; //  100/10  =10  90/10 =9 ......0/10 =0 ;

//2.2、提示用户输入分数

score = Number(prompt("请输入0-100之间的分数","0"));

var level =Math.floor(score /10); // Math.floor 取整。

switch (level){

case 10:

case 9:

document.write("你的成绩等级为A");

break;

case 8:

document.write("你的成绩等级为B");

break;

case 7:

document.write("你的成绩等级为C");

break;

case 6:

document.write("你的成绩等级为D");

break;

case 5:

case 4:

case 3:

case 2:

case 1:

case 0:

document.write("你的成绩等级为E");

break;

default:

alert("你输入的有误");

break;

}

//if语句和switch语句选择  if 一般用于大范围,switch 一般用于小范围。

/*

分支比较多且无法穷尽时最好用 if,其它情况可以视情况而定

如果数据量不是很大,并且数据是固定的可以用switch理论上switch的效率比if高。

Switch弊端:判断用户输入的数是否大于100.

*/

</script>

<script type="text/html">

//1、从键盘输入一个月份,输出对应季节 12--2 冬季  3--5 春季  6-8 夏季  9--11 秋季。

//1、定义变量 month

var month;

//2、接收数据

month = +(prompt("请输入月份:值:1-12"));

//3、数据安全校验

if(isNaN(month)){

alert("输入有误")

}else{

//4、判断输出

switch(month){

case 1:

case 2:

case 12:

document.write("这是冬季");

break;

case 3:

case 4:

case 5:

document.write("这是春季");

break;

case 6:

case 7:

case 8:

document.write("这是夏季");

break;

case 9:

case 10:

case 11:

document.write("这是秋季");

break;

default:

alert("你输入的月份有误");

break;

}

}

</script>

<script>

//2、使用Switch实现简单的计算器

//1、定义变量

var num1,num2,op,result;

//2、接收数据

num1 = +(prompt("请输入第一个数值"));

//3、较验数据

if(isNaN(num1)){

alert("你的输入第一个数值有误。");

}else{

op = prompt("请输入对应的运算符 +(加) -(减) *(乘) /(除) ");

if(op!="+" && op!="-" && op!="*" && op!="/"){

alert("你输入的运算符有误");

}else{

num2 = +(prompt("请输入第二个数值"));

if(isNaN(num2)){

alert("你的输入第二个数值有误。");

}else{

//4、输出结果

switch(op){

case "+":

result = num1 + num2;

break;

case "-":

result = num1 - num2;

break;

case "*":

result = num1 * num2;

break;

case "/":

result = num1 / num2;

break;

default:

document.write("计算有误,无法计算。")

break;

}

alert("你输入的运算结果是:" + result);

}

}

}

</script>

</html>

19js流程控制中循环

<!DOCTYPE html>

<html>

<head>

<title>19js流程控制中循环</title>

<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

</head>

<body>

</body>

<script type="text/html">

//循环

//循环结构是程序中一种很重要的结构。其特点是在给定条件成立时,反复执行某程序段,直到条件不成立为止。

//1、给定的条件称为循环条件,反复执行的程序段称为循环体

//2、循环结构简单来说就是:一次又一次的执行相同的代码块。

//现实生活中的循环

//JavaScript中的循环

//while 语句

//

/*while 格式:

while(条件表达式){ //直到条件不成立到跳出。

语句1;

语句2;

......

}

*/

//执行流程

/*

判断条件表达式是否为真,如果为真执行后面大括号中的内容。

执行完毕再次判断条件表达式是否还为真,如果为真执行后面大括号中的内容。

重复上述过程,直到条件不成立就结束while循环。

*/

//while 循环特点:

/*

如果while中的条件一开始就不成立,那么循环体中的语句永远不会被执行。

*/

var j = 10 ;

while(j<10){

alert("我是最帅。")

j++;

}

//while 循环注意点

/*

1、死循环

2、任何值都有真假性

3、while后如果只有一条语句它可以省略大括号

4、分号问题

5、最简单的死

*/

/*

var x = 10 ;

while(x<20){

//alert("我是最帅。")

x--; //死循环了。

}

*/

//1、提示用户输入一个正整数n,计算1+2+3+...+n的和。

//1、定义变量

var n,sum;

sum=0;

//2、接收输入的数值。

n = +(prompt("请输入一个正整数值"));

//3、while计算

while(n>=0){

sum = sum + n;

n--;

}

document.write(sum);

</script>

<script>

//2、获取1--100之间7的位数的个数,并打印,并统计个数。

var j = 100, i;

i=0;

while(j>0){

if(j%7==0){

document.write( j + "&nbsp;&nbsp;");

i++;

}

j--;

}

document.write("统计个数是:"+i);

</script>

</html>

20js流程控制break-continue

<!DOCTYPE html>

<html>

<head>

<title>20js流程控制break-continue</title>

<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

</head>

<body>

</body>

<script>

//break 关键字的作用。

//1、跳出switch语句

/*

var num;

num =+(prompt("请输入一个 1-12 月份"));

switch (num){

case 12:

case 1:

case 2:

alert("你输入的是冬季");

break; //找到符合条件的情况就跳出。

case 3:

case 4:

case 5:

alert("你输入的是春季");

break;

case 6:

case 7:

case 8:

alert("你输入的是夏季");

break;

case 9:

case 10:

case 11:

alert("你输入的是秋季");

break;

default:

alert("你输入的我也不知什么季节了。");

break;

}*/

//2、跳出循环语句

/*

var sum=0;

while(true){

console.log(sum);

if(10===sum){

break;

}

sum++;

}

*/

//注意点

//1、break 关键字只能用于循环语句和switch语句,在其他地方没有意义。

//break;

/*if(true){

break;

alert("我会输出么?");

}*/

//以上写法都是错的。

//2、在多层循环中,一个break语句只向外跳一层。

/*

var n=1;

while(n<10){

while(2){

console.log("我是while2");

break; //跳出while2,但是不会跳出while1

}

console.log("我是while1");

n++;

}

//3、break 后面的语句是永远不会执行到。

while(1){

break;

alert("我是否可以弹出。");

}

*/

//continue 关键字

//1、作用 :跳过当前循环体中剩余的语句而继续下一次。

var n=0;

while(n<10){

n++;

if(n%2===0){

continue; //结束本次循环,进入下一次循环

}

document.write(n+"<br/>");

}

//2、注意点

//1、只能用于循环结构,在其它地方没有意义。

//2、continue 后面的语句是永远不会被执行。

</script>

</html>

21js流程控制循环do while

<!DOCTYPE html>

<html>

<head>

<title>21js流程控制循环do while</title>

<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

</head>

<body>

</body>

<script>

//循环 do while

/*

1.do-while循环在循环的最后检查条件

2.这就意味着do-while循环能保证至少循环能执行一次

3.总的来说,do-while循环是用来给用户展示一个菜单用的

*/

/* 格式:

do{

语句1;

语句2;

......

}while(条件); 条件成立就执行。

*/

/* 执行流程

首先会执行一次循环体中的语句。

接着判断while中的条件表达式是否为真,如果为真再次执行循环体中的语句。

重复上述过程,直到条件不成立就结束while循环。

*/

var num =1,i=0;

do{

i++

console.log("我可以输出"+ i +"次");

num++;

}while(num<10);

var j=20,i=0;

do{

i++;

console.log("我可以输出"+ i +"次");

j++;

}while(j<10);

/* 特点:不管while中的条件是否成立,循环体中的语句至少会执行一遍。*/

/* 应用场景:口令校验*/

</script>

</html>

22js流程控制循环for

<!DOCTYPE html>

<html>

<head>

<title>22js流程控制循环for</title>

<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

</head>

<body>

</body>

<script type="text/html">

//for 循环

/* JavaScript 中的for语句使用最为灵活,不仅可以用于循环次数已经确定的情况,而且可以用于循环次数不确定而只给出循环结束条件的情况,它完全可以代替while语句。

*/

/* 格式

for(①初始化表达式;②循环条件表达式;④循环后操作表达式){

③执行语句;

}

*/

/* for循环执行流程

for循环开始时,会先执行初始化表达式,而且在整个循环过程中只执行一次初始化表达式

接着判断循环条件表达式是否为真,如果条件为真,就会执行循环体中的语句

循环体执行完毕后,接下来会执行循环后操作表达式

执行完循环后操作表达式,然后再次判断循环条件表达式是否为真,如果条件为真,就会执行循环体中的语句。

重复上述过程,直到条件不成立就结束for循环。

*/

for(var i=1;i<10;i++){

document.write(i+" ");

}

document.write("<br/>")

//for循环和while 循环如何选择?

//一般情况下while和for可以互换,但是如果循环执行完毕之后就不需要使用用于控制循环的增量,那么用for更好。

//输出相应的数的奇数。

var num = +(prompt("请输入一个正整数"));

for(var j=1; j<num; j++){

if(j%2===0){

continue;

}

document.write(j +" ");

}

document.write("<br/>")

var z=0;

while(z<num){

z++;

if(z%2===0){

continue;

}

document.write(z +" ");

}

/* 注意点

for循环中初始化表达式,循环条件表达式,循环后操作表达式都可以不写

for(;;){} 和 while(1){}  可以用,但是这种是死循环。

*/

</script>

<script type="text/html">

//循环嵌套练习

//1、打印好友列表

/* 好友列表1

好友1

好友2

好友3

好友列表2

好友1

好友2

好友3

*/

for(var i=1; i<3; i++){

document.write("好友列表"+ i +"<br/>");

for(var j=1; j<4;j++){

document.write("  好友"+j +"<br/>");

}

}

</script>

<script type="text/html">

//for循环嵌套实现矩形绘制

/* 需求:在界面上绘制如下图形

**********

*        *

*        *

*        *

**********

1、外循环控制行数。

2、内循环控制个数。

*/

for(var i=1; i<6;i++){

if(i==1 || i==5){

for(var j=1;j<11;j++){

document.write("*")

}

}else{

for(var j=1;j<3;j++){

document.write("*") //设置输出位置

}

}

document.write("<br/>")

}

</script>

<script type="text/html">

//3、for循环嵌套实现三角形绘制。

/*

*

**

***

****

*****

******

*/

for(var i=0; i<8; i++){

for(j=0;j<i;j++){

document.write("*");

}

document.write("<br/>");

}

</script>

<script type="text/html">

//for循环嵌套实现三角形倒绘制

for(var i=0; i<8; i++){

for(var j=i; j<8; j++){

document.write("* \t");

}

document.write("<br/>");

}

</script>

<script type="text/html">

//for循环嵌套实现打印特殊三角形

for(var i=1; i<7; i++){

for(var j=1;j<=i;j++){

document.write(j +"\t");

}

document.write("<br/>")

}

</script>

<script type="text/html">

//for循环嵌套实现打印正三角形

for(var i=0; i<=5; i++){

for(var j=0; j<5-i; j++){

document.write("-\t");

}

for(var n=1; n<=2*i+1; n++){

document.write("* \t");

}

document.write("<br/>");

}

</script>

<script>

//for循环嵌套实现打印99乘法表

for(i=1; i<=9; i++){

for(j=1;j<=i;j++){

document.write(j+"x"+i+"="+i*j + "&nbsp;&nbsp;");

}

document.write("<br/>")

}

</script>

<script>

//for循环嵌套实现打印99乘法表

for(var i=1; i<=9; i++){

for(var j=1; j<=9-i; j++){

document.write("--------");

}

for(var n=1; n<=i; n++){

document.write(n+"x"+i+"="+n*i +"&nbsp;&nbsp;")

}

document.write("<br/>")

}

</script>

</html>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容