javascript定义变量时有var和没有var的区别探讨
我们先来看一段代码
function show(){ alert(abc); } var abc="defg"; show();
有过C++或Java编程经验的人可能会说:“这程序,死定了,变量竟然在引用了该变量的函数后边定义,bug会灭掉你的。”放在浏览器上运行一下,结果怎样?完美运行!接下来我们就说一下这是咋回事——有var和没有var定义的变量的区别。
1、没有var
简明的说,定义变量时省略var是不安全的,不过是合法的。这时无论该变量是在什么位置定义的,解释器都会赋予该变量以全局作用域。
2、有var
安全的,合法的。定义的变量的作用域取决于定义的位置。至于作用域具体是什么,请参见本博客中“javascript作用域”一文。
这样,开头的那个问题可以解决了。函数中的才是对abc的定义,只不过值为undefined,这时abc有全局作用域,函数外的只是对abc的值的更新。
javascript中声明函数的方法及调用函数的返回值
htmlxmlns="http://www.w3.org/1999/xhtml"headtitle/title!--js中声明函数的方法--scripttype="text/javascript"//因为javascript是弱类型的语言,所以参数不需要加类型。函数的
JavaScript匿名函数与委托使用示例
htmlxmlns="http://www.w3.org/1999/xhtml"head!--C#匿名函数--title/titlescripttype="text/javascript"varf1=function(x,y){//【1】定义一个匿名函数,用变量f1来指向它(f1相当于一个
js创建对象的区别示例介绍
A:varobj1=obj2=newObject();与B:varobj1=newObject(),obj2=newObject();是两种不同的赋值方式,导致的结果也不一样,千万要注意喽~A的会将2个对象指向同一内存地址