> 웹 프론트엔드 > JS 튜토리얼 > JavaScript는 값 또는 참조로 변수를 전달합니까? 이 동작을 어떻게 설명할 수 있습니까?

JavaScript는 값 또는 참조로 변수를 전달합니까? 이 동작을 어떻게 설명할 수 있습니까?

Susan Sarandon
풀어 주다: 2024-12-31 19:54:14
원래의
806명이 탐색했습니다.

Does JavaScript Pass Variables by Value or by Reference, and How Can This Behavior Be Explained?

JavaScript의 전달 동작: 값 또는 참조에 의한 전달

JavaScript에서는 값 및 참조에 의한 전달 개념이 중요한 역할을 합니다. 변수와 객체가 어떻게 작동하는지 이해합니다. 종종 "참조에 의한 전달" 언어로 분류됨에도 불구하고 진실은 다소 미묘합니다.

값으로 객체 전달

객체를 인수로 전달하는 경우 함수인 경우 JavaScript는 실제로 해당 객체에 대한 참조 복사본을 전달합니다. 이는 함수 내의 객체에 대한 모든 수정 사항이 원래 객체에 영향을 미친다는 것을 의미합니다. 객체의 내용이 아닌 참조 자체가 값으로 전달되기 때문입니다.

객체 속성 수정

그러나 전달된 객체의 속성을 수정하는 경우 함수의 경우 해당 변경 사항은 함수 범위 외부에서도 유지됩니다. 예를 들어, 속성에 새 값을 할당하거나 새 속성을 추가하면 원래 개체에 영향을 미칩니다.

기본 값은 값으로 전달

객체와 달리 기본 개체는 값(예: 문자열, 숫자, 부울)은 값으로 전달됩니다. 즉, 함수 내에서 이러한 값을 수정해도 원래 값에는 영향을 미치지 않습니다.

전달 동작을 제어할 수 있는 방법이 있습니까?

JavaScript에는 다음이 있습니다. 무언가가 값으로 전달되는지 아니면 참조로 전달되는지를 제어하는 ​​명시적인 방법이 없습니다. 그러나 예측 가능하고 효율적인 코드 실행을 보장하려면 기본 전달 동작을 이해하는 것이 중요합니다.

  • 예 1:

    function modifyByRef(obj) {
      obj.value = "Modified";
    }
    
    const obj = { value: "Original" };
    modifyByRef(obj);
    console.log(obj.value); // "Modified"
    로그인 후 복사
  • 예 2:

    function modifyPrimitive(value) {
      value = "Modified";
    }
    
    let value = "Original";
    modifyPrimitive(value);
    console.log(value); // "Original"
    로그인 후 복사

모범 사례 객체 생성 복사본

객체의 완전히 독립적인 복사본을 만들려면 구조 분해와 함께 Object.sign() 또는 스프레드 연산자(...)를 사용할 수 있습니다.

결론

변수 및 객체를 효과적으로 사용하려면 JavaScript의 전달 동작을 이해하는 것이 필수적입니다. 객체는 값(참조)으로 전달되지만 함수 내의 속성 수정은 원본 객체에 영향을 미칩니다. 반면에 원시 값은 실제로 값으로 전달됩니다. 통과 동작을 식별하는 기능은 코드 정확성과 예측 가능한 결과를 보장합니다.

위 내용은 JavaScript는 값 또는 참조로 변수를 전달합니까? 이 동작을 어떻게 설명할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿