你的位置:首页 > Java教程

[Java教程]Javascript进阶篇——(流程控制语句)笔记整理


做判断(if语句)
if语句是基于条件成立才执行相应代码时使用的语句。
语法:

1 if(条件){2   条件成立时执行代码3 }

例子:假设你应聘web前端技术开发岗位,如果你会HTML技术,你面试成功,欢迎加入公司。

1 <script type="text/javascript">2   var mycarrer = "HTML";3   if (mycarrer == "HTML"){4     document.write("你面试成功,欢迎加入公司。");5   }6 </script>

 

二选一(if...else语句)
if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码。
语法:

1 if(条件){2   条件成立时执行的代码3 }else{4   条件不成立时执行的代码5 }

例子:假设你应聘web前端技术开发岗位,如果你会HTML技术,你面试成功,欢迎加入公司,否则你面试不成功,不能加入公司。

1 <script type="text/javascript">2   var mycarrer = "HTML"; //mycarrer变量存储技能3   if (mycarrer == "HTML"){4     document.write("你面试成功,欢迎加入公司。"); 5   }else{6     //否则,技能不是HTML7     document.write("你面试不成功,不能加入公司。");8   }9 </script>

 

多重判断(if...else嵌套语句)
要在多组语句中选择一组来执行,使用if..else嵌套语句。
语法:

1 if(条件1)2 { 条件1成立时执行的代码}3 else if(条件2)4 { 条件2成立时执行的代码}5 ...6 else if(条件n)7 { 条件n成立时执行的代码}8 else9 { 条件1、2至n不成立时执行的代码}

例:联合国世界卫生组织对年龄的划分标准, 44岁以下为青年;45岁至59·岁为中年人。60岁至89岁为老年人;90岁以上为长寿老年人。赵红今年99岁了,她属于哪个年龄阶段的。

 1 <script type="text/JavaScript"> 2   var myage =99;//赵红的年龄为99 3   if(myage<=44){ 4     document.write("青年"); 5   }else if(myage<=59) { 6     document.write("中年人"); 7   }else if (myage<=89){ 8     document.write("老年人"); 9   }else {10     document.write("长寿老年人");11   }12 </script>

 

多种选择(Switch语句)
当有很多种选项的时候,switch比if else使用更方便。

 1 switch(表达式) 2 { 3 case值1: 4 执行代码块 1 5 break; 6 case值2: 7 执行代码块 2 8 break; 9 ...10 case值n:11 执行代码块 n12 break;13 default:14 与 case值1 、 case值2...case值n 不同时执行的代码15 }

语法说明:
Switch必须赋初始值,值与每个case值匹配。满足执行该 case 后的所有语句,并用break语句来阻止运行下一个case。如所有case值都不匹配,执行default后的语句。
例子:我们来做个周计划,周一、二学习理念知识,周三、四到企业实践,周五总结经验,周六、日休息和娱乐。

 1 <script type="text/JavaScript"> 2   var myweek =3;//myweek表示星期几变量 3   switch(myweek){ 4     case 1: 5     case 2: 6     document.write("学习理念知识"); 7     break; 8     case 3: 9     case 4:10     document.write("到企业实践");11     break;12     case 5:13     document.write("总结经验");14     break;15     default:16     document.write("周六、日休息和娱乐");17   }18 </script>

 

重复重复(for循环)
很多事情不只是做一次,要重复做。如打印10份试卷,每次打印一份,重复这个动作,直到打印完成。这些事情,我们使用循环语句来完成,循环语句,就是重复执行一段代码。
for语句结构:

1 for(初始化变量;循环条件;循环迭代)2 { 3   循环语句 4 }

例子:假如,一个盒子里有6个球,我们每次取一个,重复从盒中取出球,直到球取完为止。

1 <script type="text/javascript">2   var num=1;3   for (num=1;num<=6;num++){ //初始化值;循环条件;循环后条件值更新4     document.write("取出第"+num+"个球<br />");5   }6 </script>

我们有1,2,3...10不同面值的钱,使用for语句完成合计,看看我们一共有多少钱?

1 <script type="text/JavaScript">2   var mymoney,sum=0;//mymoney变量存放不同面值,sum总计3   for(mymoney=1;mymoney<=10;mymoney++){ 4     sum= sum + mymoney;5   }6   document.write("sum合计:"+sum);7 </script>

 

 

反反复复(while循环)
和for循环有相同功能的还有while循环, while循环重复执行一段代码,直到某个条件不再满足。
while语句结构:

1 while(判断条件)2 {3   循环语句4 }

使用while循环,完成从盒子里取球的动作,每次取一个,共6个球。

1 <script type="text/javascript">2   var num=0; //初始化值3   while (num<=6){ //条件判断4     document.write("取出第"+num+"个球<br />");5     num=num+1; //条件值更新6   }7 </script>

 

来来回回(Do...while循环)
do while结构的基本原理和while结构是基本相同的,但是它保证循环体至少被执行一次。因为它是先执行代码,后判断条件,如果条件为真,继续循环。
do...while语句结构:

1 do2 {3   循环语句4 }5 while(判断条件)

试着输出5个数字。

1 <script type="text/javascript">2   num= 1;3   do{4     document.write("数值为:" + num+"<br />");5     num++; //更新条件6   }7   while (num<=5)8 </script>

使用do...while语句,输出6个数字。

1 <script type="text/javascript">2   var mynum =6;//mynum初值化数值为63   do{4     document.write("数字:"+mynum+"<br/>");5     mynum=mynum-1;6   }7   while(mynum>=1);8 </script>

 

退出循环break
在while、for、do...while、while循环中使用break语句退出当前循环,直接执行后面的代码。
格式如下:

1 for(初始条件;判断条件;循环后条件值更新){2   if(特殊情况)3   {break;}4   循环代码5 }

考试成绩输出,如果成绩及格继续输出下个成绩,如果成绩不及格,退出并且后面成绩不输出.

 1 <script type="text/JavaScript"> 2   var mynum =new Array(70,80,66,90,50,100,89);//定义数组mynum并赋值 3   var i=0; 4   while(i<mynum.length){ 5     if(mynum[i]<60){ 6     document.write("成绩"+mynum[i]+"不及格,不用循环了"+"<br>"); 7     break; 8     } 9     document.write("成绩:"+mynum[i]+"及格,继续循环"+"<br>");10     i=i+1;11   }12 </script>

 

 

继续循环continue
语句结构:

1 for(初始条件;判断条件;循环后条件值更新){2   if(特殊情况){3     continue;4   }5   循环代码6 }

上面的循环中,当特殊情况发生的时候,本次循环将被跳过,而后续的循环则不会受到影响。
例子:考试成绩输出,如果成绩及格继续输出下个成绩,如果成绩不及格,则不输出该成绩。

 1 <script type="text/JavaScript"> 2   var mynum =new Array(70,80,66,90,50,100,89);//定义数组mynum并赋值 3   var i; 4   for(i=0;i<mynum.length;i++){ 5     if(mynum[i]<60){ 6       document.write("成绩不及格,不输出!"+"<br>"); 7       continue; 8     } 9     document.write("成绩:"+mynum[i]+"及格,输出!"+"<br>");10   }11 </script>

 

 

在一个大学的编程选修课班里,我们得到了一组参加该班级的学生数据,分别是姓名、性别、年龄和年级,接下来呢,我们要利用JavaScript的知识挑出其中所有是大一的女生的的名字哦。

学生信息如下:

    ('小A','女',21,'大一'),  ('小B','男',23,'大三'),

    ('小C','男',24,'大四'),  ('小D','女',21,'大一'),

    ('小E','女',22,'大四'),  ('小F','男',21,'大一'),

    ('小G','女',22,'大二'),  ('小H','女',20,'大三'),

    ('小I','女',20,'大一'),  ('小J','男',20,'大三')

 1 <script type="text/javascript"> 2   //第一步把之前的数据写成一个数组的形式,定义变量为 infos 3   var infos = [ 4     ['小A','女',21,'大一'], 5     ['小B','男',23,'大三'], 6     ['小C','男',24,'大四'], 7     ['小D','女',21,'大一'], 8     ['小E','女',22,'大四'], 9     ['小F','男',21,'大一'],10     ['小G','女',22,'大二'],11     ['小H','女',20,'大三'],12     ['小I','女',20,'大一'],13     ['小J','男',20,'大三']14   ];15   //第一次筛选,找出都是大一的信息16   var arr1 = [];17   var n = 0;18   for(var i=0;i<infos.length;i++){ 19     if( infos[i][3] == "大一" ){ 20       arr1[n] = infos[i];21       document.write(arr1[n]+"<br/>");22       n=n+1;23     } 24   }25   document.write("大一人数: "+arr1.length+"<br/>"); 26   //第二次筛选,找出都是女生的信息27   for(var i=0;i<arr1.length;i++){ 28   //这里可以用switch 29     if(arr1[i][1]=='女'){30       document.write(arr1[i][0]+"<br/>");31     }32   }33 </script>

 

 

循环语句和数组联起来搞得我是乱乱的