javascript定义变量时带var与不带var的区别分析
投稿:shichen2014
这篇文章主要介绍了javascript定义变量时带var与不带var的区别,以一个简单实例分析了变量定义时带var与不带var的执行原理及用法区别,需要的朋友可以参考下
本文实例分析了javascript定义变量时带var与不带var的区别。分享给大家供大家参考。具体分析如下:
直接看实例里说明:
复制代码 代码如下:
<script language="javascript" type="text/javascript">
var abc=89;//带var,表示全局变量
function test(){
var abc=80;//在函数内部,如果不带var,表示使用函数外全局变量;带上var,表示新定义一个全局变量
}
test();
window.alert(abc);
</script>
var abc=89;//带var,表示全局变量
function test(){
var abc=80;//在函数内部,如果不带var,表示使用函数外全局变量;带上var,表示新定义一个全局变量
}
test();
window.alert(abc);
</script>
严格来说:函数体内不带var,并不是指定义一个变量,而是进行变量赋值,即var abc;abc=8。在函数体内如果进行赋值 abc=80(不带var),实际过程是这样的——该语句先在函数体内查找变量abc,如果找不到,它会往上在函数体外继续查找变量abc,如果还是找不到,最后没有办法,只能在函数体外定义变量var abc。
所以,为什么
复制代码 代码如下:
function test(){
abc = 80;
}
abc = 80;
}
能够在函数外部直接调用变量abc,也就是这么一个原因。
希望本文所述对大家的javascript程序设计有所帮助。