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

JS中的块级作用域

2017-02-14 17:10 204 查看
JS中是没有块级作用域作用域这个概念,为实现块级作用域可通过闭包的形式实现,下面通过一个例子来说一下JS中的块级作用域。

function outputName(count){
for (var i = 0; i <count; i++) {
console.log(i);
}
}
console.log(i)
}


在JAVA,c++等语言中,变量i只定义在for循环语句中,循环一旦结束,变量i就会被销毁,而在JS中,变量i存在整个outputName函数的活动对象中,变量i可以在函数内部随处访问。如上面例子中的第二条的输入语句将输出变量i的值。

JS中的模仿块级作用域(即私有作用域)的语法如下代码所示。

(function(){
//块级作用域
})();


需要临时存放一些变量,可以使用私有作用域,修改上例中的代码,在for循环中添加一个私有作用域,在匿名函数中的任何变量,都会在执行结束后被销毁。所以在第二条打印输出i时,会出现错误。而私有作用域可以访问count,是因为这个匿名函数是一个闭包,它能够访问包含作用域中的任何变量。

function outputName(count){
(function(){
for (var i = 0; i <count; i++) {
console.log(i);
}
})();
console.log(i);//打印输出i时报错
}


这种技术经常在全局作用域中被用在函数外部,从而限制向全局作用域中添加过多的变量和函数。由一个很多开发人员编写的大型应用程序中,通过私有作用域的使用,可以解决由于过多全局变量和函数产生的命名冲突。通过创建私有作用域,每个开发人员可以使用自己的变量,而不用担心搞乱全局作用域。

(function(){
var now=new Date();
if (now.getMinutes()==01) {
console.log(now);
var test1=document.getElementById("test1");
test1.style.display="block";
}
})();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: