JavaScript의 인수 함수에 대한 자세한 설명(예제 포함)

不言
풀어 주다: 2018-10-23 15:43:48
앞으로
2357명이 탐색했습니다.
이 글은 JavaScript의 인수 함수에 대한 자세한 설명을 제공합니다(예제 포함). 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

개요

JavaScript의 함수는 여러 가지 면에서 다른 객체 지향 언어와 다릅니다.

  1. 함수 오버로딩이 없습니다.

  2. 실제 매개변수 목록을 나타내는 배열과 유사한 객체 인수가 있습니다.

1. 함수 오버로딩

간단히 말해서 JAVA는 동일한 클래스에서 여러 함수를 허용합니다. 함수 이름은 같지만 매개변수 선언이 다른 것을 함수 오버로딩이라고 합니다.

하지만 JS는 함수 오버로딩을 지원하지 않습니다.

function foo(num) {
    console.log(num + 100)
}
function foo(num) {
    console.log(num + 200)
}

foo(100);  // 300
로그인 후 복사

동일한 이름을 가진 두 함수가 js에 정의된 경우 해당 이름은 나중에 정의된 함수에만 속합니다.

2. 인수 클래스 배열

함수 인수 개체는 화살표가 아닌 모든 함수에서 사용할 수 있는 지역 변수이며 배열과 유사한 개체입니다. 인수 객체를 사용하여 함수 내에서 함수의 (실제) 매개변수를 참조할 수 있습니다.

function foo() {
    console.log(arguments);
}

foo(1, "foo", false, {name: "bar"}); // [1, "foo", false, object]
로그인 후 복사
function foo() {
    console.log(typeof arguments);
}

foo(1, "foo", false, {name: "bar"}); // object
로그인 후 복사

따라서 인수는 길이 속성과 인덱스 요소에 대한 첨자를 갖는 배열 스타일 객체입니다.

JavaScript의 인수 함수에 대한 자세한 설명(예제 포함)

3. 인수 속성

length

function foo(num1, num2, num3) {
    console.log(arguments)
}

foo(1);  // [1]
로그인 후 복사

길이 속성은 함수가 선언될 때 형식 매개변수의 개수가 아니라 함수에 전달된 실제 매개변수 개수를 나타냅니다.

callee
callee는 함수 자체를 나타내며, 함수 내에서 callee를 통해 자신을 호출할 수 있습니다.

4. 실제 배열로 변환

  1. slice

arguments 객체는 다른 배열 방법을 지원하지 않지만 Function.call을 사용하여 간접적으로 호출할 수 있습니다.

function sayHi() {
    console.log(Array.prototype.slice.call(arguments, 0))
}
sayHi("hello", "你好", "bonjour")  //["hello", "你好", "bonjour"]
로그인 후 복사
  1. splice

function sayHi() {
    console.log(Array.prototype.splice.call(arguments, 0));
}
sayHi("hello", "你好", "bonjour")  //["hello", "你好", "bonjour"]
로그인 후 복사
  1. Array.from

function sayHi() {
    console.log(Array.from(arguments));
}
sayHi("hello", "你好", "bonjour")  //["hello", "你好", "bonjour"]
로그인 후 복사
  1. Expand 연산자

function sayHi(...arguments) {
    console.log(arguments);
}
sayHi("hello", "你好", "bonjour")  //["hello", "你好", "bonjour"]
로그인 후 복사

5. 엄격 모드

엄격 모드 그리고 비엄격 모드, 인수의 성능은 동일하게 표시되지 않습니다.

// 严格模式
function foo(a, b) {
    "use strict";
    console.log(a, arguments[0]);
    a = 10;
    console.log(a, arguments[0]);
    arguments[0] = 20;
    console.log(a, arguments[0]);
    b = 30;
    console.log(b, arguments[1])
}
foo(1);
输出:
1 1
10 1
10 20
30 undefined

// 非严格模式
function foo(a, b) {
    console.log(a, arguments[0]);
    a = 10;
    console.log(a, arguments[0]);
    arguments[0] = 20;
    console.log(a, arguments[0]);
    b = 30;
    console.log(b, arguments[1]);
}
foo(1);
输出:
1 1
10 10
20 20
30 undefined
로그인 후 복사

비엄격 모드에서는 전달된 매개변수, 실제 매개변수 및 인수의 값이 공유됩니다. 아무것도 전달되지 않으면 실제 및 인수 값이 공유되지 않습니다.

Strict 모드에서는 실제 매개변수와 인수의 값이 공유되지 않습니다.


위 내용은 JavaScript의 인수 함수에 대한 자세한 설명(예제 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!