JavaScript-4.2函数,变量作用域---ShinePans

<html>
	<head>
		<meta http-equiv="content-type" content="text/html;charset=GB2312"/>
		<title> 4.2 函数和变量作用域 </title>
		<!--脚本部分-->
		<script type="text/javascript">
			var v1,v2;

			v1=10;
			v2=20;

			function a(){
				var v2,v3;
				alert("v1="+v1+"\r\nv2= "+v2+"\r\nv3="+v3);
				v2=v3=40;

				function b(v3,v4){
					alert("v3 = "+v3+"\r\nv4="+v4);
					v2=v3=80;
					}
					b(v3);
					alert("v2="+v2+"\r\nv3="+v3);
					alert(v4);
				}
				a();
				</script>
			</head>
			<body style="overflow:auto;">
			</body>
		</html>

函数外的变量在函数里面无需声明直接使用,函数里面声明的变量在函数外部是无效的.

JavaScript-4.2函数,变量作用域---ShinePans

时间: 2024-08-08 13:56:07

JavaScript-4.2函数,变量作用域---ShinePans的相关文章

javascript 闭包与函数变量作用域

浏览器事件循环工作原理 浏览器有一个事件循环用于检查事件队列,处理延时的事件.UI事件(例如:点击,滚动等),ajax回调,以及提供给setTimeout()和setInterval()的回调,都会依次被事件循环处理. 因此,当调用setTimeout()函数时,即使延迟的时间被设置为0,提供的回调也会被排队 回调会呆在队列中,直到指定的时间用完后,引擎开始执行动作(如果它当前不执行其他动作) 因此,即使setTimeout()回调被延迟0ms,它仍然会被排队,并且直到函数中其他非延迟的语句被执

JavaScript解析顺序和变量作用域

javascript解析顺序和变量作用域 一.变量的作用域 1.全局变量:在代码中任何地方都能够访问得到的变量,拥有全局的作用域.        A.最外层函数外面定义的变量.        B.没有定义直接赋值的变量,拥有全局属性. 2.局部变量:只能在固定的代码片段(函数片段中)中访问得到.        A.函数内部定义的变量,就是局部变量.        B.参数也是局部变量.     二.javascript预解析顺序    1.<Script></script>块依次解

JavaScript 基础(五) 函数 变量和作用域

函数定义和调用 定义函数,在JavaScript中,定义函数的方式如下: function abs(x){ if(x >=0){ return x; }else{ return -x; } } 上述abs() 函数的定义如下: function 指出这是一个函数定义; abs 是函数的名称: (x) 括号内列出函数的参数,多个参数以,分隔: {...}之间的代码是函数体,可以包含若干语句,甚至可以没有任何语句. 注意:函数体内部的语句在执行时,一旦执行到return 时,函数就执行完毕,并将结果

关于JS函数变量作用域

这样一段代码: var a = 123 function f() { console.log(a); var a = 1; console.log(a); } 执行f(),会怎样输出呢? 你可能会想当然的第一次console.log输出的是123,也就是全局变量的值,而第二次显示是1. 但是,最先输出的是undefined. 函数的作用域始终优先于全局作用域,所以局部变量a会覆盖掉与他同名的全局变量,尽管第一次console.log的时候,a还没有被正式定义,但该变量已经存在本地空间了.即输出u

javaScript的闭包 js变量作用域

js的闭包 js的变量作用域: var a=90; //定义一个全局变量 function test(){ a=123; //使用外层的 a变量 } test(); document.write("a="+a); var a=90; //定义一个全局变量 function test(){ var a=123; //定义一个局部变量 } test(); document.write("a="+a); a=90; //没有var ,就会试着去找(父函数 的 a),如果找

关于javascript函数变量作用域问题

作用域 1.如果一个变量在函数体内部申明,则该变量的作用域为整个函数体,在函数体外不可引用该变量: 2.JavaScript的函数在查找变量时从自身函数定义开始,从"内"向"外"查找.如果内部函数定义了与外部函数重名的变量,则内部函数的变量将"屏蔽"外部函数的变量.

原型模式故事链(5)--JS变量作用域、作用域链、闭包

上一章 JS执行上下文.变量提升.函数声明 传送门:https://segmentfault.com/a/11... 本次我们主要讲讲变量作用域和闭包变量作用域:顾名思义:变量起作用的范围.变量分为全局变量和局部变量.全局变量:在任何地方都能用,在所有函数之外.局部变量:只能在定义它的函数中,以及它的子函数中使用. 当前作用域没有定义的变量,称为自由变量. 举例子: <!DOCTYPE html> <html> <head> <title>dsfg</

js的变量,变量作用域,作用域链

变量声明: 使用var关键字声明,如果使用没有声明的变量,则JS会自动声明此变量根据变量作用域.如果变量只声明为赋值,则此时值是undefined.重复声明变量,在JS不会报错,会依据最后一次的声明来处理变量. 变量作用域: 一个变量的作用域是,程序代码定义这个变量的区域,全局变量在程序代码内任何地方都可以访问. 包括在{}函数,对象内的变量(属性)成为局部变量. 在函数体内定义的变量成为局部变量,作用域也是局部,函数参数也是局部变量. 他们只在函数体内有意义. 在函数体内,局部变量优先于全局变

JavaScript函数定义和调用 变量作用域

本文是笔者在看廖雪峰老师JavaScript教程时的个人总结 JavaScript中函数定义可以是这样的格式 function 函数名(参数) { 函数体 } 也可以是这样的格式 var 函数名 = function (参数) { 函数体 }; 关键字一:arguments 获取全部参数 只在函数内部起作用,并且永远指向当前函数的调用者传入的所有参数.arguments类似Array但它不是一个Array.第一个参数是arguments[0]....[n] 关键字二:rest 获取 获取除了已定