6个函数的output看JS的块级作用域

1.

var output = 0;
(function() {
    output++;
}());
console.log(output);

函数对全局的output进行操作,因为JS没有块级作用域,所以output为1.

2.

var output = 0;
(function(output) {
    output++;
}(output));
console.log(output);

函数传入output的值,但函数内只是对参数output做加一操作,没有对全局的output进行操作,所以output为0.

3.

var output = 0;
(function() {
    output++;
}(output));
console.log(output);

函数内的output值因为函数本身没用,也没有通过参数传递进入,所以对全局的output进行加一操作,output为1.

4.

var output = 0;
(function() {//A
    var output = 0;
    (function() {//B
        output++;
    }());
}());
console.log(output);

函数B的output加一操作是对A函数中的output进行操作,对全局的output无影响,output为0.

5.

var output = 0;
(function() {//A
    (function() {//B
        output++;
    }());
    var output = 0;
}());
console.log(output);

B中的output无法获取全局的output,所以output加一操作无效。所以output为0.

6.

var output = 0;
(function() {//A
    (function() {//B
        output++;
    }(output));
}());
console.log(output);

执行的是全局中的output加一操作,所以output为1.

时间: 2024-10-07 05:55:35

6个函数的output看JS的块级作用域的相关文章

js没有块级作用域但有函数作用域

任何一对花括号中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域. 作用域永远都是任何一门编程语言中的重中之重,因为它控制着变量与参数的可见性与生命周期.首先我们理解两个概念:块级作用域与函数作用域. 什么是块级作用域呢? 任何一对花括号({和})中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域. 函数作用域就是定义在函数中的参数和变量在函数外部是不可见的. 大多数类C语言都拥有块级作用域,JS却没有.请看下文de

js作用域链 js没有块级作用域

arguments和函数内定义的变量或函数->父级->下一个父级->.....->全局环境中的变量或函数 if(true){ var a=1; } console.log(a);js没有块级作用域, 变量a直接添加到当前的执行环境中.  java有块级作用域,if语句结束后会销毁if中定义的变量

js没有块级作用域

今天看一篇介绍ECMAscript6的博文时,看到let命令的时候突然有点蒙逼....... let命令:let用于变量声明,与var用法类似,但是let是一个局部变量,只在声明的代码块中有效. { let a = 10; var b = 20; } a // not defined b // 20 看到这我觉得这个块级作用域是函数作用域,但是块级作用域和函数作用域是不一样的,比如: function demo(){ var a=1; } console.log(a); a//not defin

js模仿块级作用域

var i = 5; var i; alert(i); 当一个变量被声明赋值之后,如果再对其声明,则不会改变上一次赋值后的值,所以i的值还是5,只有重新赋值之后,才会改变,如: var i = 5; var i = 6; alert(i); i现在的值是6: JS中没有块级作用域,如果想要块级作用域的效果,可以进行模仿,如: (function () { for (var i = 0; i < 5; i++) { } })(); alert(i); //出错 这方法可以理解为把块级作用域放在一个

JS 模仿块级作用域

function outputNumbers(count) { for (var i=0; i<count; i++) { console.log(i); } var i;  // 重新声明变量 console.log(i);  // 计数 } 上述中,重复声明了i变量,但是JS从来不会告诉你是否多次声明了同一变量:遇到这种情况,它只会对后续的声明视而不见 不过,它会执行后续声明中变量的初始化.匿名变量可以用来模仿块级作用域并避免这个问题. (function() { // 这里是块级作用域(私

JS的块级作用域

今天带来的是 "对<你不知道的js>中块级作用域的总结" 分享: 1)用with从对象中创建出来的作用域只在with声明中而非外部作用域有效,同时可以访问已有对象的属性并将其添加到已有对象上 代码demo: var obj = { a:1, b:2, c:3 }; with(obj){ a=3; b=4; c=5; d=6; } console.log(obj);//3,4,5 2)try/catch 的catch分句会创建一个块级作用域,其中声明的变量仅在catch内部有

4.2 js没有块级作用域

JavaScript没有块级作用域.在其他语言上,比如C语言中,有花括号封闭的代码块都有自己的作用域,(如果用ECMAScript的话来讲,就是他们自己的执行环境),因而支持根据条件来定义变量.例如,下面的代码效果 if (true) { var color  = "blue"; } alert(color);//blue 这里是一个if语句中定义了一个变量color,如果是在C,C++或者Java中,color会在if执行后被销毁.但是在JavaScript中,if语句中的变量声明会

JS 没有块级作用域

在函数(方法)中声明的所有变量,他们在整个函数中都有定义 var scope="abc"; function f() { alert(scope);  //显示undefine var scope="local"; alert(scope); //显示local } 原因:由于作用域规则的限制,输出的并不是abc.由于局部变量在真个函数体内都是有定义的,这就意味这在真个函数题中都隐藏了同名的全局变量 上面的例子和下面的效果相同: function f() { var

js中块级作用域