javascript中函数表达式的一些问题???
var a=function(){
console.log("1");
}
a();
a();
a();
//1
//1
//1
var a=function(){
console.log("1");
a=function(){
console.log("2");
}
}
a();
a();
a();
//1
//2
//2
var a=function(){
console.log("1");
a=function(){
console.log("2");
}
}
var c=a;
c();
a();
a();
//1
//2
//2
var a=function(){
console.log("1");
a=function(){
console.log("2");
}
}
var c=a;
a();
a();
c();
//1
//2
//1
我给出我不太成熟的理解哈,var a是函数表达式,也是局部变量,而a=function()是全局变量吧,对于第二个代码段,局部变量执行一次也就被回收啦,所以后面的也就执行全局变量,,,,不知道理解的对不对啊?
更新一下--------------------------------------------------------------------------------------------------------------------------------
var a=100;
function fn(){
alert(a);
var a=200;
alert(a);
}
fn();
fn();
//undefined
//200
//undefined
//200
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
函数就是对象,对象都是引用赋值,所以a=function() {...}就是指在内存中有一个函数,a指向此函数的地址,c=a就是指让c也指向此函数的地址,然后再给a赋值就是指让a指向其他内存地址。理解了这点上述问题就都迎刃而解了。
这里从头到尾都没有局部变量,也和回收搭不上关系。你又没有在函数里面var一个a,所以函数里面的a是仍旧是全局变量。
所以最后两个程序的差别在于,先执行c函数会修改a函数,而反过来则不会修改c函数。
你这个不涉及回收(也就是传说中的闭包)相关的概念。
你这里只是简单的赋值而已。
var a定义了一个变量,变量的值是一个函数。而且是全局的变量。
你在函数中,是对变量a的值进行了改写,所以执行一次之后,变量a的值发生了变化。
如果你这样写,可能理解起来会更深刻一些: