JavaScript 学习笔记之语句_基础知识
基本格式:
if (){
}else if (){
}else{
}
执行流程:
二、循环语句
2.1前测试循环语句:在循环体内的代码被执行之前就对出口条件求值。
2.1.1while语句
基本格式:
do {
} while ()
执行流程:
2.1.2 for语句
基本格式:
for (;;){
}
执行流程:
2.2后测试循环语句:在循环体中的代码被执行之后才会测试出口条件。
2.2.1、do-while语句
基本格式:
do {
} while () ;
执行流程:
三、精准的迭代语句:for-in
基本格式:
for ( 属性 in 对象 ){
}
作用:重复执行指定对象的所有属性,可以用来枚举对象的属性。
例子:
点击下面的按钮,循环遍历对象 "person" 的属性。
如果要表示的对象为null或者undefined,循环体将不再执行,或者抛出错误,因此,在执行for-in循环时,应该先检测改对象的属性值是不是null或者undefined。
四、Lable语句
基本语法:
Label:
如: begin: for (var i = 0; i
alert(i);
}
举例说明lable语句的作用:
未加lable:
var num = 0;
for (var i = 0 ; i for (var j = 0 ; j if( i == 5 && j == 5 ){
break;
}
num++;
}
}
alert(num);//95
加入lable:
var num = 0;
outPoint:
for (var i = 0 ; i for (var j = 0 ; j if( i == 5 && j == 5 ){
break outPoint;
}
num++;
}
}
alert(num); //55
第一个例子输出95不难理解,第二个例子为什么输出55呢,是因为执行到break outpoint时,直接跳出到putpoint层,执行alert语句。
如果把第二个例子改成下面这样:
var num = 0;
for (var i = 0 ; i outPoint:
for (var j = 0 ; j if( i == 5 && j == 5 ){
break outPoint;
}
num++;
}
};
alert(num);//95
这个结果和第一个例子的结果是一致的。
五、break和continue语句
5.1break语句:
var num = 0;
for (var i = 1 ; i if(i%5==0){
break;
}
num++;
};
alert(num);//4
break语句执行后跳到alert语句
5.2continue语句:
var num = 0;
for (var i = 1 ; i if(i%5==0){
continue;
}
num++;
};
alert(num);//8
continue语句执行后跳到for()循环,继续执行循环,直到循环条件不成立。
六、with语句
基本语法:
with (object) {
statements
}
举例说明:
不使用with的写法:
var qs = location.search.substring(1);
var hostName = location.hostname;
var url = location.href;
alert(qs);
alert(hostName);
alert(url);
使用with的写法:
with(location){
var qs = search.substring(1);
var hostName = hostname;
var url = href;
}
alert(qs);
alert(hostName);
alert(url);
从上面例子可以看出:with语句的作用是将代码的作用域设置到一个特定的对象中、减少的重复输入。
但是js的解释器需要检查with块中的变量是否属于with包含的对象,这将使with语句执行速度大大下降,并且导致js语句很难被优化。
因此并不建议大规模使用with语句。
七、swith语句
基本语法:
switch () {
case :
break;
case :
break;
...
default
}
执行流程:
switch语句可以是任何数据类型,每个case的值也不一定是常量,也可以是变量、表达式等,例如:
switch ("hello world") {
case "hello" + " world":
alert("Greeting was found.");
break;
case "goodbye":
alert("Closing was found.");
break;
default:
alert("Unexpected message was found.");
}
var num = 25;
switch (true) {
case num alert("Less than 0.");
break;
case num >= 0 && num alert("Between 0 and 10.");
break;
case num > 10 && num alert("Between 10 and 20.");
break;
default:
alert("More than 20.");
}
switch语句在比较时使用的是全等操作符比较,因此不会发生类型转换。
练习:
for(;;){
alert("2");//输出多少次2?
}
以上就是本文的全部内容了,希望对小伙伴们能够有所帮助。
上一篇: php不变形缩放图片
推荐阅读
-
JavaScript DOM学习第八章 表单错误提示_基础知识
-
[walkerlee原作]对PHP之函数sprintf()的学习研究笔记_PHP
-
Symfony2框架学习笔记之表单用法详解,symfony2学习笔记_PHP教程
-
JavaScript高级程序设计 事件学习笔记_javascript技巧
-
Javascript入门学习第六篇 js DOM编程_基础知识
-
Symfony2学习笔记之插件格式分析,symfony2学习笔记_PHP教程
-
JSON 学习之完全手册 图文_javascript技巧
-
[C语言学习笔记五]复合语句和操作符的区分
-
JavaScript 学习笔记(十六) js事件_基础知识
-
MySQL基础语句【学习笔记】