JavaScript的函数

这篇博客详细介绍了JavaScript中的函数,包括函数定义、全局和局部变量的区别、变量生存周期、作用域的概念以及闭包的原理。在变量作用域部分,强调了从内向外查找变量的规则,而闭包则是JavaScript中的一种重要特性。此外,还涉及到词法分析的过程,解释了在函数调用时如何形成激活对象(AO)并分析函数参数、局部变量和函数声明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一.函数

二.函数的全局变量和局部变量

2.1局部变量

2.2全局变量

2.3变量生存周期

2.4作用域

 2.5闭包:

三.词法分析


一.函数

函数定义:JavaScript中的函数和Python中的非常类似,只是定义方式有点区别。

// 普通函数定义 
function f1() { 
console.log("Hello world!"); 
} 

// 带参数的函数 
function f2(a, b) { 
console.log(arguments); // 内置的arguments对象 
console.log(arguments.length); 
console.log(a, b); 
}

// 带返回值的函数 
function sum(a, b){ 
return a + b; 
}
sum(1, 2); // 调用函数 

// 匿名函数方式 
var sum = function(a, b){ 
return a + b; 
} 
sum(1, 2); 
24
// 立即执行函数 
(function(a, b){ 
return a + b; 
})(1, 2); 

JavaScript Console 对象 | 菜鸟教程 (runoob.com)

二.函数的全局变量和局部变量

2.1局部变量

在JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它(该变量的作用域是函数内部)。只要函数运行完毕,本地变量就会被删除。

2.2全局变量

在函数外声明的变量是全局变量,网页上的所有脚本和函数都能访问它。

2.3变量生存周期

  • javaScript变量的生命期从它们被声明的时间开始。
  • 局部变量会在函数运行以后被删除。
  • 全局变量会在页面关闭后被删除。

2.4作用域

首先在函数内部查找变量,找不到则到外层函数查找,逐步找到最外层。

例子一.

var city = "BeiJing"; 
function f() { 
var city = "ShangHai"; 
function inner(){ 
var city = "ShenZhen"; 
console.log(city); 
}
inner(); 
}
f(); //输出结果是?

例子二.

ar city = "BeiJing"; 
function Bar() { 
console.log(city); 
}
function f() { 
var city = "ShangHai"; 
return Bar; 
} 
var ret = f(); 
ret(); // 打印结果是?

 2.5闭包:

var city = "BeiJing"; 
function f(){ 
var city = "ShangHai"; 
function inner(){ 
console.log(city); 
} 
return inner; 
} 
var ret = f(); 
ret(); 

三.词法分析

avaScript中在调用函数的那一瞬间,会先进行词法分析。
词法分析的过程: AO =null  AO = age = undefind = 22
当函数调用的前一瞬间,会先形成一个激活对象:Avtive Object(AO),并会分析以下3个方面:

  1. 函数参数,如果有,则将此参数赋值给AO,且值为undefined。如果没有,则不做任何操作。
  2. 函数局部变量,如果AO上有同名的值,则不做任何操作。如果没有,则将此变量赋值给AO,并且值为undefined。
  3. 函数声明,如果AO上有,则会将AO上的对象覆盖。如果没有,则不做任何操作。
  4. 函数内部无论是使用参数还是使用局部变量都到AO上找。
var age = 18; 
function foo(){ 
console.log(age); // undefind 
var age = 22; 
console.log(age); // 22 
} 
foo(); // 问:执行foo()之后的结果是? 

 

 

var age = 18; 
function foo(){ 
console.log(age); 
var age = 22; 
console.log(age); 
function age(){ 
console.log("呵呵"); 
} 
console.log(age); 
} 
foo(); // 执行后的结果是?

 

词法分析过程: 
1、分析参数,有一个参数,形成一个 AO.age=undefine; 
2、分析变量声明,有一个 var age, 发现 AO 上面已经有一个 AO.age,因此不做任何处理 
3、分析函数声明,有一个 function age(){...} 声明, 则把原有的 age 覆盖成 AO.age=function()
{...};

最终,AO上的属性只有一个age,并且值为一个函数声明 

执行过程: 
注意:执行过程中所有的值都是从AO对象上去寻找 

1、执行第一个 console.log(age) 时,此时的 AO.age 是一个函数,所以第一个输出的一个函数 
2、这句 var age=22; 是对 AO.age 的属性赋值, 此时AO.age=22 ,所以在第二个输出的是 2 
3、同理第三个输出的还是22, 因为中间再没有改变age值的语句了 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值