js变量小秘密
2012-12-28 18:04
218 查看
var a = 1; function b() { a = 10; return; } b(); alert(a); -------------------------------------------------------- var a = 1; function b() { a = 10; return; function a() {} } b(); alert(a);
这个的值是神马呢?
第一个不用想就知道 是10
第二个有return 看着也是 应该是10
悄悄运行下看看,你会发现 原来第二个竟然是1
这是为神马呢
先复习一个概念 变量声明在作用域内是始终可见的
然后 想想 函数声明 function a() == var a=function()
运行b时,进入函数 发现竟然有一个 var a声明,悄悄 提前 往下执行
也是说 var a=undefiend;这里是错误解释下方修正
也就是说var a = function(){}
然后变量赋值a = 10;
所以这里 它是局部变量了。。
相关文章推荐
- 如何减少JS的全局变量污染
- js的全局变量和局部变量
- 如何将JS的变量值传递给ASP变量
- js中变量和jsp中java代码中变量互相访问解决方案
- js的全局变量和局部变量
- JS 调用后台变量的值
- js 变量及变量的数据类型
- js-变量定义关键字const,var,let
- JS 中对变量类型的判断
- js获取父窗口的变量和函数方法
- JS获取URL中的变量
- js变量、作用域和内存问题
- JS字符串替换函数全部替换方法 JS 正则表达式如何使用变量
- js中变量跟jsp中java代码中变量互相访问解决方案
- 通过alpha变量实现图片透明度渐变(仍然用到JS缓冲运动框架)
- js delete 用法(删除对象属性及变量)
- js 多种变量定义(对象直接量,数组直接量和函数直接量)
- JS全局变量和局部变量最新解析
- js之变量介绍
- JS里面匿名函数的调用 & 变量作用域的实验