함수의 클로저에 액세스
클로저는 해당 범위에 대한 링크를 형성하여 다음에서 변수에 액세스할 수 있도록 하는 함수입니다. 함수가 실행된 후에도 해당 범위를 유지합니다. JavaScript에서는 이 클로저가 숨겨져 있어 프로그래밍 방식으로 해당 속성에 액세스하기가 어렵습니다.
함수의 클로저에 액세스할 수 있습니까?
답은 '예'입니다. 색다른 방법이 필요합니다. 한 가지 접근 방식은 프런트엔드 환경에서 MutationObserver를 활용하는 것입니다. 이 기술에는 문서에 삽입된 스크립트 태그의 소스 코드를 수정하여 검사하려는 기능을 노출시키는 작업이 포함됩니다.
제공된 예는 이 접근 방식을 보여줍니다. 새 스크립트 태그의 삽입을 감시하는 MutationObserver를 생성합니다. 삽입되면 스크립트 코드의 일부를 대체하여 내부 변수와 해당 값을 노출합니다.
<code class="js">new MutationObserver((mutations, observer) => { // Find the script tag to tamper with const tamperTarget = document.querySelector('script + script'); if (!tamperTarget) { return; } observer.disconnect(); tamperTarget.textContent = tamperTarget.textContent.replace( 'return function', 'window.y = y; return function' ); }).observe(document.body, { childList: true });</code>
조사하려는 스크립트 태그 내에서 변수 x를 통해 클로저에 액세스합니다. 스크립트의 코드를 수정하면 클로저에서 전역 변수로 y 변수를 노출하여 해당 속성을 검사할 수 있습니다.
<code class="js">var x = (function(){ var y = 5; return function() { alert(y); }; })(); // Access y here with x somehow console.log(window.y); // 5</code>
이 기술은 클로저의 속성에 액세스하고 검사하는 방법을 제공합니다. 비록 함수의 범위 내에 숨겨져 있더라도 말입니다.
위 내용은 JavaScript에서 함수의 클로저에 접근할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!