JS与ES6的声明命令(2)- function

一 function声明

  • 定义方式:

    • function functionName( arg0, arg1,arg2,…){ 语句… }
  • 调用方式
    functionName ( arg0, arg1,arg2,… || 不带参数)

  • 特点:

    1、参数行为

    • ECMAScript的参数在内部是用一个数组来表示的,函数接收到的始终为这个类数组(arguments)
    • 在函数体内可以通过arguments对象来访问这个参数数组,从而获取传递给函数的每一个参数
    • 用方括号 [ ] +下标值来访问每一个元素
    • 用length属性来确定传递进来多少个参数
    • argument的值永远与对应命名参数的值保持同步。传入的参数变量和argument获取对应下标的值,会访问相同的内存空间,但彼此的内存空间是独立的,值会同步
    • 没有传递至的命名参数将自动被赋予undefined值
    • ECMAScript中的所有参数传递的都是值,不可能是引用类型的传递
function a(num1, num2){
    arguments[1] = 10;
    console.log('arguments[1]: ', arguments[1]);//10
    console.log('num2: ', num2);//10
}

a(1,2)

2、返回值

  • ECMAScript中的函数在定义时不必知道是否返回值,可以通过return语句后跟要返回的值来实现返回值
  • 位于return语句之后的任何代码都永远不会执行

3、没有函数签名
因为函数的参数是由多个0或多个值的数组来表示的,ECMAScript中的函数,命名的参数事先不需要创建一个函数签名,调用时也不用验证签名是否一致

4、没有重载

  • ECMAScript中的函数没有签名,因此不能重载
  • 后定义的函数会覆盖先定义的函数
function add(num){
    return num + 100; //被覆盖,不执行
}

function add(num){
    return num + 200; //执行
}

add(100);
console.log('add(100): ', add(100));//300
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值