您的位置:首页 > Web前端 > JavaScript

Javascript的for-in语句和with语句

2017-08-20 12:58 639 查看

1.for-in语句

for-in是一种精准的迭代语句,可以用来枚举对象的属性,以下是for-in的语法:

for (property in expression) statement

下面的示例中,使用for-in循环来显示BOM中window对象的所有属性。每次执行循环时,都会将window对象中存在的一个属性名赋给propName.这个过程会一直持续到对象中的所有属性都枚举一遍为止。在这里var操作符不是必需的,但是为了保证局部变量,加上它。

for (var propName in window){
document.write(propName);
}


但是,如果表示要迭代的对象的变量值为null或undefined,就会抛出错误,建议在使用for-in循环之前,先检测确认对象的值是不是null或undefined。

2.with语句

作用是将代码的作用域设置到一个特定的对象中,with语句语法如下

with(expression) statement;

定义with语句主要是为了简化多次编写同一个对象的工作,如下面例子:

var qs=location.search.substring(1);
var hostName=location.hostname;
var =location.href;


都包含了location对象,如果使用with语句,就可以写成:

with(location){
var qs=search.substring(1);
var hostName=hostname;
var url=href;
}


重写之后,使用with关联了location对象。每个变量首先被认为是一个局部变量,而如果在局部环境中找不到该变量的定义,就会查询location对象中是否有同名的属性。如果发现了同名属性,则以location对象属性的值作为变量的值。

严格模式下不允许使用with语句,同时大量使用with语句也会导致性能下降。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: