javascript中错误使用var造成undefined

在javascript中根据变量作用的范围不同分为局部变量和全局变量,直接定义的变量是全局变量,全局变量可以被所有的脚本访问;在函数中定义的变量是局部变量,局部变量只在函数内有效。

如果全局变量和局部变量使用相同的变量名,则局部变量将会覆盖全局变量。

例子代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>js中全局变量与局部变量</title>
	</head>
	<body>
		<script type="text/javascript">
			var a = "全局变量";
			function test1()
			{
				var a = "局部变量";

				alert(a);
			}

			function test2()
			{
				alert(a);

				var a = "局部变量";

				alert(a);
			}

			function test3()
			{
				alert(a);

				a = "局部变量";

				alert(a);
			}
		</script>

		<input type="button"  value="test1" onclick="test1()"/>
		<input type="button"  value="test2" onclick="test2()"/>
		<input type="button"  value="test3" onclick="test3()"/>

	</body>
</html>

运行的结果是这样的:

点击test1 ,弹出局部变量。

点击test2,弹出undefined,再弹出局部变量

 
点击test3,弹出全局变量,再弹出局部变量


这就是使用var和不使用的区别所在:

如果使用var,那么程序会强制定义一个新变量。

如果没有使用var,系统会优先在当前上下文中搜索是否存在该变量,只有在不存在的前提下才会重新定义一个新变量。


test3中,使用的变量a均为全局变量,第一次直接输出了全局变量,第二次是直接为全局变量赋值之后使用。

test1和test2中都存在在function中使用var定义同名新变量,会导致函数中的变量覆盖掉全局变量。所以在test2中:第一次输出的a是已经被覆盖了的局部变量a,但是没有给予初值,所以会出现undefined这个结果。这样使用变量实际上是错误的,大家应该避免。



时间: 2024-11-03 06:12:30

javascript中错误使用var造成undefined的相关文章

javascript中错误使用var造成undefined_javascript技巧

在javascript中根据变量作用的范围不同分为局部变量和全局变量,直接定义的变量是全局变量,全局变量可以被所有的脚本访问:在函数中定义的变量是局部变量,局部变量只在函数内有效.如果全局变量和局部变量使用相同的变量名,则局部变量将会覆盖全局变量.例子代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>js中全局变量与局部变量</title>

JavaScript中错误正确处理方式,你用对了吗?

JavaScript的事件驱动范式增添了丰富的语言,也是让使用JavaScript编程变得更加多样化.如果将浏览器设想为JavaScript的事件驱动工具,那么当错误发生时,某个事件就会被抛出.理论上可以认为这些发生的错误只是JavaScript中的简单事件. 本文将会讨论客户端JavaScript中的错误处理.主要介绍JavaScript中的易犯错误.错误处理.异步代码编写等内容. 下面就让我们一起看看如何正确处理JavaScript中的错误. Demo演示 本文中使用的demo可以在GitH

Javascript 中 null、NaN和undefined的区别总结_javascript技巧

1.类型分析: js中的数据类型有undefined,boolean,number,string,object等5种,前4种为原始类型,第5种为引用类型. 代码 复制代码 代码如下: var a1; var a2 = true; var a3 = 1; var a4 = "Hello"; var a5 = new Object(); var a6 = null; var a7 = NaN; var a8 = undefined; alert(typeof a); //显示"u

JavaScript中的关键字&quot;VAR&quot;使用详解 分享

JScript的语法教程里面说在声明变量时忽略var关键字是完全合法的.但是事实常常又证明想当然的结果是不可靠的.   看看下面这几个例子的结果就知道问题了: 这三个例子的执行结果分别是: 复制代码 代码如下: Results#region Results No.1 0 undefined No.2 0 1 No.3 0 undefined #endregion 原 来JavaScript的变量也是有作用域的,只是它非常的笼统,就分为全局变量和函数变量.在第二个例子中得到0和1,是因为所有的变量

Javascript中的数据类型之旅_基础知识

虽然Javascript是弱类型语言,但是,它也有自己的几种数据类型,分别是:Number.String.Boolean.Object.Udefined.Null.其中,Object属于复杂数据类型,Object   由无序的键值对组成.其余几种都属于简单数据类型.注意:变量类型首字母大写,而变量值首字母是小写的. JavaScript不支持自定义类型,所以JavaScript中的所有值都属于这六种类型之一. 根据ECMAScript 5.1的规范,javascript中共有六种数据类型,分别为

深入探讨javascript中的数据类型_基础知识

学一门编程语言,无非两方面:一是语法,二是数据类型.类C语言的语法不外乎if.while.for.函数.算术运算等,面向对象的语言再加上object. 语法只是语言设计者预先做的一套规则,不同语言语法不尽相同,但都有一些共通点,对于熟悉一两门编程语言的人,学其他的编程语言时,语法往往不是问题(当然,如果你一直学的是类C语言,那么首次接触lisp时肯定也要花些时间),学习的重点往往是数据类型及其相关操作上,不是有句老话:"数据结构+算法=程序"!其次,有些语言的语法本身就存在设计问题(j

详解javascript中原始数据类型Null和Undefined_javascript技巧

当讨论JavaScript中的原始数据类型时,大多数人都知道的基本知识,从String,Number到Boolean.这些原始类型相当简单,行为符合常识.但是,本文将更多聚焦独特的原始数据类型Null和Undefined,是什么让他们如此相似,却又似是而非. 一.理解Null和Undefined 在JavaScript中,null是字面量同时也是语言中的关键字,用来表示无法识别的对象值.换句话说,这用来表示"无值(no value)".虽然相似,undefined实际上代表了不存在的值

JavaScript中的prototype和constructor简明总结

 一直没弄清楚JavaScript中的prototype和constructor属性,今天看了看书,总算有点眉目了 一.constructor constructor的值是一个函数.在JavaScript中,除了null和undefined外的类型的值.数组.函数以及对象,都有一个constructor属性,constructor属性的值是这个值.数组.函数或者对象的构造函数.如:   代码如下:var a = 12, // 数字     b = 'str', // 字符串     c = fa

JavaScript中的prototype和constructor简明总结_基础知识

一.constructorconstructor的值是一个函数.在JavaScript中,除了null和undefined外的类型的值.数组.函数以及对象,都有一个constructor属性,constructor属性的值是这个值.数组.函数或者对象的构造函数.如: 复制代码 代码如下: var a = 12, // 数字    b = 'str', // 字符串    c = false, // 布尔值    d = [1, 'd', function() { return 5; }], //