最详细的JavaScript高级教程(十二)函数

本文详细介绍了JavaScript中的函数,包括函数的定义、函数指针、参数处理、返回值、作用域、函数提升、作为参数传递、内部属性如arguments和callee、外部属性如length和prototype,以及call和apply的应用。此外,还讨论了ES6中的函数参数解构赋值。函数在JavaScript中是对象,可以作为参数传递并拥有自己的作用域特性,理解这些概念对于深入学习JavaScript至关重要。
摘要由CSDN通过智能技术生成

函数也是对象,也是引用类型。

定义

两种定义方法都是等价的

function sum(arg1, arg2){
    return arg1 + arg2;
}

var sum2 = function(arg1, arg2){
    return arg1 + arg2;
}

函数指针

需要理解,函数名只是函数的指针,可以新建指针指向一个函数,也可以将原先指向函数的指针清空

function sum(arg1, arg2){
    return arg1 + arg2;
}

var sum1 = sum;  // 将sum1指向函数
alert(sum1(1, 2)); // 使用sum1
sum = null;     // 清空原指针
alert(sum(1, 2));  // 报错,sum is not a function

没有重载

因为函数名字是指针,所以我们很好理解为什么js中没有重载的概念,因为指针不能指向两块内存。

那么想一想,如果函数定义两遍会怎么样?这事实上相当于后面的函数名覆盖了前面的函数名,只有后面的函数生效。

function ret(){
    alert('1');
}
function ret(){
    alert('2');
}
ret(); // 显示2,显示1的函数被覆盖

函数的参数

有意思的是,在调用函数的时候,可以传递比声明更多的参数,也可以不传参数。原因是不管传递多少参数,js都是用一个数组来接收参数的。如果传递了没有定义的参数,函数体内部用arguements也可以获取到参数。

arguement本身不是数组,它是一个对象,只是可以像数组那样去使用。

// 不定义参数名称
function SayHi(){
    alert(arguments[0]);
}
SayHi("Hi");

arguement.length可以获得传入的参数数量

function SayHi(){
    alert(arguments.length);
}
SayHi("Hi");  // 输出1

注意:在严格模式下,修改arguements的值和修改参数值不会互相影响,在非严格模式下,两者可以互相影响。

函数的返回值

在函数定义的时候,不需要指定是否有返回值

// 定义函数
function sayHi(name, message){
    
}

如果一个函数没有return任何值&

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值