기능
몇 가지 핵심 사항:
a) 함수는 JavaScript에서 일급 시민입니다(중요)
~ ~ .
c) 이 함수는 독립 변수 범위
를 정의합니다.
정의 방법
이름이 지정된 함수는 다른 함수 내부에 정의되지 않는 한 전역 함수입니다.
// 全局的命名函数 function add(x, y) { return x + y; } console.info(add(100, 200)); //300
익명 함수는 일반적으로 변수에 할당된 후 해당 변수를 통해 호출됩니다.
var func = function (x, y) { return x + y; } console.info(func(5, 2)); //7
console.info( function (x, y) { return x + y; }(100, 200) //立即调用 );
이름이 지정된 함수를 먼저 사용한 후 정의할 수 있습니다
console.info(sum(10, 10)); function sum(num1, num2) { return num1 + num2; }
을 사용하기 전에 먼저 익명 함수를 정의해야 합니다.
//console.info(sumFunc(10, 10)); //Uncaught TypeError: Property 'sumFunc' of object [object Object] is not a function var sumFunc = function (num1, num2) { return num1 + num2; }; console.info(sumFunc(10, 10));
함수 반환 값:
function func() { } console.info(func()); //undefined function func2() { return; //空的返回语句 } console.info(func2()); //undefined
귀환에 숨겨진 구덩이:
var func = function (x, y) { var sum = x + y; return { value : sum } }
단,
var func = function (x, y) { var sum = x + y; return { value: sum }; } console.info(func(5,5)); //undefined
func(5,5)를 호출하면 정의되지 않은 것으로 표시됩니다
편집자는 반환 뒤에 세미콜론을 추가했지만 이 경우에는 쓸모가 없습니다.
함수는 객체입니다:
function add(x, y) { return x + y; } console.info(add(100, 200)); //300 var other = add; //other和add引用同一函数对象 console.info(other(300, 400)); //700 console.info(typeof other); //function console.info(add === other); //true
중첩된 정의 함수:
function outerFunc(a, b) { function innerFunc(x) { return x * x; } return Math.sqrt(innerFunc(a) + innerFunc(b)); } console.info(outerFunc(3, 4)); //5
외부 변수 액세스:
var globalStr = 'globalStr'; function outerFunc2(argu) { var localVar = 100; function innerFunc2() { localVar++; console.info(argu + ":" + localVar + ":" + globalStr); } innerFunc2(); //hello:101:globalStr } outerFunc2("hello");
함수를 반환하는 함수:
function outerFunc(x) { var y = 100; return function innerFunc() { console.info(x + y); } } outerFunc(10)(); //110