웹 프론트엔드 JS 튜토리얼 JavaScript 인수 객체에 대한 포괄적인 소개

JavaScript 인수 객체에 대한 포괄적인 소개

Oct 13, 2016 am 09:10 AM

1. 인수란 무엇입니까

MDN에서 설명:

인수는 배열과 유사한 객체입니다. 함수에 전달된 매개변수 목록을 나타냅니다.

먼저 예시를 통해 JavaScript의 인수가 어떤 모습인지 직관적으로 이해해 보겠습니다.

function printArgs() { 
 
console.log(arguments); 
 
} 
 
printArgs("A", "a", 0, { foo: "Hello, arguments" });
로그인 후 복사

실행 결과는 다음과 같습니다.

["A", "a", 0, Object]
로그인 후 복사

얼핏 결과는 배열이지만 실제 배열은 아니므로 인수는 배열과 유사한 객체( 실제를 알고 싶다. 배열과 배열 유사 객체의 차이점은 끝까지 읽을 수 있습니다.

함수가 실행될 때 함수에 전달되는 모든 매개변수를 나타내는 인수로 표시되는 내용을 살펴보세요. 위의 예에서는 printArgs 함수에 전달된 4개의 매개변수를 나타냅니다. 인수[0], 인수[1]...을 사용하여 단일 매개변수를 얻을 수 있습니다.

2. 인수 연산

2.1 인수 길이

arguments는 길이 속성을 포함하는 배열과 유사한 객체입니다. 함수에 전달된 매개변수입니다.

function func() { 
 
console.log("The number of parameters is " + arguments.length); 
 
} 
 
func(); 
 
func(1, 2); 
 
func(1, 2, 3);
로그인 후 복사

실행 결과는 다음과 같습니다.

The number of parameters is 0 
 
The number of parameters is 2 
 
The number of parameters is 3
로그인 후 복사

2.2 인수를 배열로 변환

일반적으로 인수를 배열로 변환하려면 다음 방법을 사용합니다.

Array.prototype.slice.call(arguments);
로그인 후 복사

더 짧게 작성하는 방법도 있습니다.

[].slice.call(arguments);
로그인 후 복사

여기서 Array의 프로토타입 수준에서는 호출하지 않고 빈 배열의 슬라이스 메서드를 간단히 호출합니다.

위 두 메소드를 변환할 수 있는 이유는 무엇인가요?

우선, 슬라이스 메소드로 얻은 결과는 배열이고, 매개변수는 인수입니다. 실제로 특정 조건을 만족하는 모든 객체는 슬라이스 메소드를 통해 배열로 변환될 수 있습니다. 예를 들면:

const obj = { 0: "A", 1: "B", length: 2 }; 
 
const result = [].slice.call(obj); 
 
console.log(Array.isArray(result), result);
로그인 후 복사

실행 결과는

true ["A", "B"]
로그인 후 복사

위의 예에서 볼 수 있듯이 조건은 다음과 같습니다. 1) 속성은 0, 1, 2입니다. ...;2 )에는 길이 속성이 있습니다.

또한 주목해야 할 점은 함수의 인수가 유출되거나 전달될 수 없다는 것입니다. 이는 무엇을 의미합니까? 다음의 인수 누출 예를 살펴보십시오.

// Leaking arguments example1: 
 
function getArgs() { 
 
    return arguments; 
 
} 
 
// Leaking arguments example2: 
 
function getArgs() { 
 
    const args = [].slice.call(arguments); 
 
    return args; 
 
} 
 
// Leaking arguments example3: 
 
function getArgs() { 
 
    const args = arguments; 
 
    return function() { 
 
    return args; 
 
    }; 
 
}
로그인 후 복사

위 접근 방식은 함수의 인수 객체를 직접 누출합니다. 최종 결과는 V8 엔진이 최적화를 건너뛰게 되어 상당한 결과가 발생한다는 것입니다. 성능 손실.

다음과 같이 할 수 있습니다.

function getArgs() { 
 
    const args = new Array(arguments.length); 
 
    for(let i = 0; i < args.length; ++i) { 
 
    args[i] = arguments[i]; 
 
    } 
 
    return args; 
 
}
로그인 후 복사

매우 궁금합니다. 인수를 사용할 때마다 첫 번째 단계는 일반적으로 인수를 배열로 변환하는 것입니다. 인수는 쉽게 성능 저하로 이어질 수 있으므로 인수를 배열 객체로 직접 디자인하는 것은 어떨까요?

이것은 이 언어의 시작 부분부터 시작해야 합니다. Array 객체에 toString, Join, reverse 및 sort의 네 가지 메서드가 있었던 언어 초기에 인수가 도입되었습니다. 인수가 Object에서 상속되는 가장 큰 이유는 이 네 가지 메서드가 필요하지 않기 때문입니다. 이제 Array에는 forEach, map, filter 등과 같은 강력한 메서드가 많이 추가되었습니다. 그렇다면 새 버전에서 Array의 인수를 다시 상속하도록 하는 것은 어떨까요? 실제로 이는 ES5 초안에 포함되었지만 향후 호환성을 위해 위원회에서 궁극적으로 거부되었습니다.

2.3 인수 값 수정

엄격 모드와 비엄격 모드에서는 함수 매개 변수 값을 수정한 결과가 다릅니다. 아래 두 가지 예를 살펴보십시오.

function foo(a) { 
 
"use strict"; 
 
console.log(a, arguments[0]); 
 
a = 10; 
 
console.log(a, arguments[0]); 
 
arguments[0] = 20; 
 
console.log(a, arguments[0]); 
 
} 
 
foo(1);
로그인 후 복사

출력:

1 1 
 
10 1 
 
10 20
로그인 후 복사

비엄격 모드의 또 다른 예:

function foo(a) { 
 
console.log(a, arguments[0]); 
 
a = 10; 
 
console.log(a, arguments[0]); 
 
arguments[0] = 20; 
 
console.log(a, arguments[0]); 
 
} 
 
foo(1);
로그인 후 복사

출력은 다음과 같습니다.

1 1 
 
10 10 
 
20 20
로그인 후 복사

위의 두 예에서 볼 수 있듯이 엄격 모드에서는 함수의 매개변수가 인수 객체와 연결되지 않으며 한 값을 수정해도 다른 값은 변경되지 않습니다. 비엄격 모드에서는 둘이 서로 영향을 미칩니다.

2.4 한 함수에서 다른 함수로 매개변수 전달

다음은 한 함수에서 다른 함수로 매개변수를 전달할 때 권장되는 방법입니다.

function foo() { 
 
bar.apply(this, arguments); 
 
} 
 
function bar(a, b, c) { 
 
// logic 
 
}
로그인 후 복사

2.5개의 인수와 오버로딩

오버로딩은 여러 언어에서 사용할 수 있지만 JavaScript에서는 사용할 수 없습니다. 먼저 예를 살펴보겠습니다.

function add(num1, num2) { 
 
console.log("Method one"); 
 
return num1 + num2; 
 
} 
 
function add(num1, num2, num3) { 
 
console.log("Method two"); 
 
return num1 + num2 + num3; 
 
} 
 
add(1, 2); 
 
add(1, 2, 3);
로그인 후 복사

실행 결과는 다음과 같습니다.

Method two 
 
Method two
로그인 후 복사

따라서 JavaScript에서는 함수가 서로 다른 매개변수에 따라 서로 다른 호출을 하지 않습니다.

JavaScript에는 오버로딩이 없나요? 아니요. 인수를 사용하여 오버로딩을 시뮬레이션할 수 있습니다. 여전히 위의 예입니다.

function add(num1, num2, num3) { 
 
    if (arguments.length === 2) { 
 
    console.log("Result is " + (num1 + num2)); 
 
    } 
 
    else if (arguments.length === 3) { 
 
    console.log("Result is " + (num1 + num2 + num3)); 
 
    } 
 
} 
 
add(1, 2); 
 
add(1, 2, 3)
로그인 후 복사

실행 결과는 다음과 같습니다.

Result is 3 
 
Result is 6
로그인 후 복사

3. ES6의 인수

3.1 확장 연산자

밤나무에 직접:

function func() { 
 
console.log(...arguments); 
 
} 
 
func(1, 2, 3);
로그인 후 복사

실행 결과는 다음과 같습니다.

1 2 3
로그인 후 복사

간단히 말하면 확장 연산자는 인수를 독립 매개변수로 확장할 수 있습니다.

3.2 나머지 매개변수

그래도 최고:

function func(firstArg, ...restArgs) { 
 
console.log(Array.isArray(restArgs)); 
 
console.log(firstArg, restArgs); 
 
} 
 
func(1, 2, 3);
로그인 후 복사

실행 결과는 다음과 같습니다.

true 
 
1 [2, 3]
로그인 후 복사

위 결과에서 알 수 있듯이 , 나머지 매개변수는 명시적으로 지정된 매개변수를 제외한 나머지 매개변수 세트를 나타내며 유형은 배열입니다.

3.3 기본 매개변수

밤나무:

function func(firstArg = 0, secondArg = 1) { 
 
console.log(arguments[0], arguments[1]); 
 
console.log(firstArg, secondArg); 
 
} 
 
func(99);
로그인 후 복사

실행 결과는

99 undefined 
 
99 1
로그인 후 복사

기본 매개변수에는 없음을 알 수 있습니다. 인수에 대한 영향, 인수는 여전히 함수를 호출할 때 전달된 모든 매개변수를 나타냅니다.

3.4개의 배열 인수

Array.from()은 배열과 유사한 모든 객체를 배열로 변환할 수 있는 매우 권장되는 방법입니다.

4. 배열 및 배열 유사 객체

배열에는 인덱스라는 하나의 기본 기능이 있습니다. 이는 일반 물체에는 없는 것입니다.

const obj = { 0: "a", 1: "b" }; 
 
const arr = [ "a", "b" ];
로그인 후 복사

obj[0]과 arr[0]을 사용하여 원하는 데이터를 얻을 수 있지만 데이터를 얻는 방법은 정말 다릅니다. obj[0]은 객체의 키-값 쌍을 사용하여 데이터에 액세스하고, arr[0]은 배열의 인덱스를 사용합니다. 실제로 Object와 Array의 유일한 차이점은 Object의 속성은 문자열이고 Array의 인덱스는 숫자라는 것입니다.

배열형 객체를 살펴보겠습니다.

伪数组的特性就是长得像数组,包含一组数据以及拥有一个 length 属性,但是没有任何 Array 的方法。再具体的说,length 属性是个非负整数,上限是 JavaScript 中能精确表达的最大数字;另外,类数组对象的 length 值无法自动改变。

如何自己创建一个类数组对象?

function Foo() {} 
 
Foo.prototype = Object.create(Array.prototype); 
 
const foo = new Foo(); 
 
foo.push(&#39;A&#39;); 
 
console.log(foo, foo.length); 
 
console.log("foo is an array? " + Array.isArray(foo));
로그인 후 복사

执行结果是:

["A"] 1 
 
foo is an array? false
로그인 후 복사

也就是说 Foo 的示例拥有 Array 的所有方法,但类型不是 Array。

如果不需要 Array 的所有方法,只需要部分怎么办呢?

function Bar() {} 
 
Bar.prototype.push = Array.prototype.push; 
 
const bar = new Bar(); 
 
bar.push(&#39;A&#39;); 
 
bar.push(&#39;B&#39;); 
 
console.log(bar);
로그인 후 복사

执行结果是:

Bar {0: "A", 1: "B", length: 2}
로그인 후 복사

参考:

JavaScript中的数组与伪数组的区别

MDN arguments

Avoid modifying or passing arguments into other functions — it kills optimization

Optimization killers

Why isn't a function's arguments object an array in Javascript?

arguments 对象

Advanced Javascript: Objects, Arrays, and Array-Like objects

JavaScript 特殊对象 Array-Like Objects 详解

What is a good way create a Javascript array-like object?


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

내 자신의 JavaScript 라이브러리를 어떻게 작성하고 게시합니까? 내 자신의 JavaScript 라이브러리를 어떻게 작성하고 게시합니까? Mar 18, 2025 pm 03:12 PM

기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

브라우저에서 성능을 위해 JavaScript 코드를 최적화하려면 어떻게해야합니까? 브라우저에서 성능을 위해 JavaScript 코드를 최적화하려면 어떻게해야합니까? Mar 18, 2025 pm 03:14 PM

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? 프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? Apr 04, 2025 pm 02:42 PM

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

브라우저 개발자 도구를 사용하여 JavaScript 코드를 효과적으로 디버그하려면 어떻게해야합니까? 브라우저 개발자 도구를 사용하여 JavaScript 코드를 효과적으로 디버그하려면 어떻게해야합니까? Mar 18, 2025 pm 03:16 PM

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

Java의 컬렉션 프레임 워크를 효과적으로 사용하려면 어떻게해야합니까? Java의 컬렉션 프레임 워크를 효과적으로 사용하려면 어떻게해야합니까? Mar 13, 2025 pm 12:28 PM

이 기사는 Java의 컬렉션 프레임 워크의 효과적인 사용을 탐구합니다. 데이터 구조, 성능 요구 및 스레드 안전을 기반으로 적절한 컬렉션 (목록, 세트, ​​맵, 큐)을 선택하는 것을 강조합니다. 효율적인 수집 사용을 최적화합니다

소스 맵을 사용하여 조정 된 JavaScript 코드를 디버그하는 방법은 무엇입니까? 소스 맵을 사용하여 조정 된 JavaScript 코드를 디버그하는 방법은 무엇입니까? Mar 18, 2025 pm 03:17 PM

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

Chart.js : Pie, Donut 및 Bubble Charts를 시작합니다 Chart.js : Pie, Donut 및 Bubble Charts를 시작합니다 Mar 15, 2025 am 09:19 AM

이 튜토리얼은 Chart.js를 사용하여 파이, 링 및 버블 차트를 만드는 방법을 설명합니다. 이전에는 차트 유형의 차트 유형을 배웠습니다. JS : 라인 차트 및 막대 차트 (자습서 2)와 레이더 차트 및 극지 지역 차트 (자습서 3)를 배웠습니다. 파이 및 링 차트를 만듭니다 파이 차트와 링 차트는 다른 부분으로 나뉘어 진 전체의 비율을 보여주는 데 이상적입니다. 예를 들어, 파이 차트는 사파리에서 남성 사자, 여성 사자 및 젊은 사자의 비율 또는 선거에서 다른 후보자가받는 투표율을 보여주는 데 사용될 수 있습니다. 파이 차트는 단일 매개 변수 또는 데이터 세트를 비교하는 데만 적합합니다. 파이 차트의 팬 각도는 데이터 포인트의 숫자 크기에 의존하기 때문에 원형 차트는 값이 0 인 엔티티를 그릴 수 없습니다. 이것은 비율이 0 인 모든 엔티티를 의미합니다

초보자를위한 타이프 스크립트, 2 부 : 기본 데이터 유형 초보자를위한 타이프 스크립트, 2 부 : 기본 데이터 유형 Mar 19, 2025 am 09:10 AM

엔트리 레벨 타입 스크립트 자습서를 마스터 한 후에는 TypeScript를 지원하고 JavaScript로 컴파일하는 IDE에서 자신의 코드를 작성할 수 있어야합니다. 이 튜토리얼은 TypeScript의 다양한 데이터 유형으로 뛰어납니다. JavaScript에는 NULL, UNDEFINED, BOOLEAN, 번호, 문자열, 기호 (ES6에 의해 소개 됨) 및 객체의 7 가지 데이터 유형이 있습니다. TypeScript는이 기반으로 더 많은 유형을 정의 하며이 튜토리얼은이 모든 튜토리얼을 자세히 다룹니다. 널 데이터 유형 JavaScript와 마찬가지로 Null in TypeScript

See all articles