乐趣区

关于javascript:学习笔记函数声明和函数表达式

函数申明

  • 必须有函数名
function func(){}

函数申明如果呈现在表达式的地位,则被转化为函数表达式

// 圆括号(分组操作符)内只能是表达式
(function foo() {});
 
// 在数组只能是表达式
[function bar() {}];
 
// 逗号也只能操作表达式
1, function baz() {};

const obj = {aa: function Inner() {return '123'}()}

console.log(obj);
  • 函数申明会晋升
func();

function func(){}

函数表达式

  • 函数名可选
const func = function(){}

const func2 = function Inner(){console.log(Inner);
}

console.log(Inner);

命名的函数表达式,函数名在内部是有效的,只能在函数外部应用。

面试题

var a = 100;

if (function b() {}) {a += typeof (b);
}

console.log(a);
  • 函数表达式不存在变量晋升

实参和形参

  • 函数的实参个数 arguments.length;
  • 函数的形参个数 funcName.length;
function Test(a){console.log(arguments.length, '实参');
  console.log(Test.length, '形参');
}

Test(1,2)

实参 arguments[0],形参 a,尽管它们的存储地位是不同的,然而它们是一一隐射关系,一一映射的要害,是须要实参传值,如果不传值,则无奈建设关系,有一一映射关系时,批改形参时,实参也会被批改,否则不会。

function Test(a){
  a =100;
  console.log(arguments);
}

Test(1,2)



function Test(a,b){
  b =100;
  console.log(arguments[1]);
}

Test(1)
  • 形参的默认值是 undefined
  • 当实参为 undefined,则取值形参;当形参为 undefined,则取值实参;当都为 undefiend,则为 undefined

    function Test(a,b){console.log(a,b);
    }
    
    // 下面的代码等于上面的代码
    function Test(a=undefined,b=undefined){console.log(a,b);
    }
    
    Test(1,2)
    
    function Test1(a = 10,b){console.log(a,b);
    }
    
    Test1(undefined,2)
退出移动版