js中变量的声明

大家都知道js中变量的声明是要提前的,以下有4个例子:

1.if(!"t" in window){

var t = 1;

}

alert(t);答案是undefined,为什么呢,就是因为变量声明提前了,所以t是在window对象里面的,但是没有走下面的判断,所以并没有赋值,答案就是undefine

2.var num = 100;

function fn(){

var num = num + 1;

return num;

}

falert(n());答案依然是NaN,因为在函数体内部首先把var num提前,这样在赋值的时候去的num + 1中的值是undefined,这样进行运算后答案就是NaN,记住我们找对象的时候是

层级往上面找的,找不到才找外面的。

3.var b = (function(){

function fn(){

return 1;

}

return fn();

function fn(){

return 2;

}

var fn;

fn = 3

})();

alert(b);答案是2,因为首先把var fn提前,然后函数体那样子定义也是一种函数的声明,并且函数的声明会在同名参数之前,所以就是var ,fn,fn,然后就renturn了,没有走之后的fn=3,所以答案就是2

4.function aa(a,b,c){

function a(){}

console.log(a);

console.log(aa);

console.log(arguments);

var a = "ee";

var aa = "444";

arguments = 6;

console.log(a);

console.log(aa);

console.log(arguments);

}

aa(1,2,3);答案是 function a(){}

undefined

[function,2,3]

ee

444

6 我们在理解变量声明的时候,首先是var的,然后是函数体的,最后是参数

时间: 2024-08-03 21:16:47

js中变量的声明的相关文章

PHP和JS中变量作用域

一,PHP中变量作用域 对于大多数PHP的变量只有一个作用域.在用户自定义函数里采用局部变量作用域.所有的函数内使用的变量被设置为局部变量.例如: <?php $a=1; function test() { echo $a; } test(); ?> 这段程序不会输出任何的东西因为echo语句要输出局部变量 $a ,而函数内的 $a 从未被赋过值.你可能注意到和C语言有点小小的区别,C中全局变量可以直接在函数内引用,除非它被一个局部变量所覆盖.因为这使得人们可能不注意修改了全局变量的值.在PH

js中变量名提升和函数名提升

首先,js中变量没有块级作用域,但是有函数作用域,即只有函数可以约数变量的作用域. 并且,函数的实质也是一个变量,所以可以改变它的值,即赋值.所以变量名提升和函数名提升非常相像. 1.变量名的提升发生在函数内部.看下面的例子.说明:第一个因为弹出undefined,相当于在上面定义了var num;因为函数内部,定义了var num=20:就相当于在一开始定义了var num;这就是变量名的提升. var num = 10; function func() { alert(num); //und

关于js中变量声明和作用域的理解

1. var是声明一个变量:虽然声明了这个变量,但在存入值之前,它的初始值是 undefined:2.全局变量:拥有全局作用域,在js代码中的任何地方都是有定义的:3.局部变量:在函数内声明的变量只在函数内有定义,作用域是局部的,只在函数内有定义:4.全局作用域编写代码时可以不写var,但声明局部变量时必须使用var语句;5.在函数体内,局部变量的优先级高于同名的全局变量.如果局部变量和全局变量同名,那么全局变量会被局部变量所遮盖:但全局变量的值不会改变:6.作用域链查找规则:自上而下(一个或多

JS中的函数声明存在的“先使用,后定义”

首先看一段JS代码,其中使用了两种方式声明了两个函数,分别在不同的地方调用两个函数: 1 <script> 2 'use strict'; 3 // 输出hello函数 4 console.log(hello); 5 // 定义hello函数 6 function hello(){ 7 alert("Hello"); 8 } 9 // 输出hi变量 10 console.log(hi); 11 // 给hi赋一个函数 12 var hi = function(){ 13 a

简单说明一下JS中的函数声明存在的“先使用,后定义”

首先看一段JS代码,其中使用了两种方式声明了两个函数,分别在不同的地方调用两个函数: 1 <script> 2 'use strict'; 3 // 输出hello函数 4 console.log(hello); 5 // 定义hello函数 6 function hello(){ 7 alert("Hello"); 8 } 9 // 输出hi变量 10 console.log(hi); 11 // 给hi赋一个函数 12 var hi = function(){ 13 a

关于JS中变量提升的规则和原理的一点理解

????关于变量提升,以前在一些教程和书籍上都听到过,平时开发中也知道有这个规律,但是今天突然在一个公开课中听到时,第一反应时一脸懵逼,然后一百度,瞬间觉得好熟悉啊,差点被这个概念给唬住了,不信我给你看个栗子,你也会恍然大悟的: (function(){ console.log(v); var v = 'I love you'; console.log(v); })() // undefined I love you ????这就是一个典型的变量提升的例子了,规则是怎样的呢,我的理解是在一个作用

js中变量注意事项

变量声明 ECMAScript中的变量是弱类型的(同一个变量可以保存任何数据类型). 通过var关键字来定义变量: 未经过初始化的变量的默认值是undefined: 使用var声明的变量是当前作用域的局部变量(如果在函数中定义一个变量,在函数执行完成后该变量就会被销毁): 没通过var关键字声明的变量会被自动声明为全局变量. 1 // 3 2 var iNum; 3 console.log(iNum); // undefined 4 5 // 4 6 function fnTest(){ 7 v

JS中变量的存储

JS中的变量是保存在栈内存中的 基本数据类型的值直接在栈内存中存储: 值与值之间是独立存在的,修改一个变量不会影响其他变量: var a=20; var b=a; a++; 对象是保存到堆内存中的,每创建一个新的对象,就会在堆内存中开辟一个新的空间: 而变量保存的是对象的内存地址(对象的引用),如果两个变量保存的是同一个对象引用,当一个变量修改属性是,另一个也会受到影响: var obj1=new Object(); obj1.name="mike"; var obj2=obj1; o

js中变量提升

1 var v='Hello World'; 2 (function(){ 3 alert(v); 4 var v='I love you'; 5 })() 会出现alert出来的是undefined,原因是因为在函数域里定义一个和外部变量一样名称的变量时,变量的声明会提升至第一句,赋值则不会变.所以上述语句其实是这样执行的 var v='Hello World'; (function(){ var v; alert(v); v='I love you'; })()