JavaScript 매개변수 전달 메커니즘: 값으로 아니면 참조로?
JavaScript는 많은 프로그래밍 언어와 마찬가지로 해당 언어의 동작에 대한 의문을 제기하는 경우가 많습니다. 매개변수 전달 메커니즘. 이 경우, 인기 있는 JavaScript 참고서의 특정 사례를 통해 독자는 언어에서 매개변수 전달의 본질을 숙고하게 되었습니다.
질문:
혼란은 다음에서 발생합니다. my라는 매개변수가 함수 내에서 정의되지 않은 것처럼 보이지만 나중에 다시 정의되는 예입니다. 함수의 매개변수 목록에 명백한 참조가 없으면 독자는 JavaScript가 참조 또는 값으로 매개변수를 전달하는지 궁금해합니다. 또한 내부 함수에서 어떤 함수도 반환되지 않는다는 사실은 잠재적인 클로저 동작에 대한 이해를 더욱 복잡하게 만듭니다.
답변:
JavaScript의 매개변수 전달 동작을 올바르게 이해하려면 , 원시 값과 객체를 구별하는 것이 중요합니다.
기본 값과 객체 객체:
제공된 예에서 my 매개 변수는 정의된 개체에 대한 참조입니다. 나중에 함수에서. 이 참조를 전달하면 함수 내에서 변경된 내용(예: l 및 w 속성 추가)이 원본 개체를 업데이트합니다. 그러나 함수 내에서 my 참조 자체를 재할당하려고 시도하면(교체 예제에서 볼 수 있듯이) 호출자의 참조에 영향을 미치지 않습니다.
클로저:
예제는 영향을 미치지 않습니다. 다른 중첩 함수에서는 함수가 반환되지 않으므로 클로저 동작을 보여주지 않습니다. 다른 함수 내에 정의된 함수가 반환된 경우에만 클로저가 발생하여, 바깥쪽 함수가 반환된 후에도 바깥쪽 범위의 변수에 액세스할 수 있습니다.
위 내용은 JavaScript 매개변수는 값으로 전달됩니까, 아니면 참조로 전달됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!