⊗jsPmMCPPE 500 of 505 menu

자바스크립트에서 클로저를 통해 부모 요소를 모듈에 전달하기

다음과 같은 요소들이 있다고 가정해 보겠습니다:

<div id="div1">1</div> <div id="div2">2</div> <div id="div3">3</div> <div id="res"></div> <button id="btn">click me</button>

이 요소들을 다음 모듈이 처리한다고 가정해 보겠습니다:

;(function(selector1, selector2, selector3, selector4, selector5) { let div1 = document.querySelector(selector1); let div2 = document.querySelector(selector2); let div3 = document.querySelector(selector3); let res = document.querySelector(selector4); let btn = document.querySelector(selector5); btn.addEventListener('click', function() { let num1 = Number(div1.textContent); let num2 = Number(div2.textContent); let num3 = Number(div3.textContent); res.textContent = num1 + num2 + num3; }); })('#div1', '#div2', '#div3', '#res', '#btn');

보시다시피, 모듈에 전달되는 매개변수의 수가 다소 많아 불편함을 초래합니다. 일반적으로 이 경우 다음과 같이 처리합니다: 모듈이 작업하는 모든 요소의 공통 부모를 모듈에 전달한 다음, 모듈 내부에서 이 부모로부터 다양한 요소를 가져옵니다.

우리 태그에 공통 부모를 만들어 봅시다:

<div id="parent"> <div id="div1">1</div> <div id="div2">2</div> <div id="div3">3</div> <div id="res"></div> <button id="btn">click me</button> </div>

이제 모듈 코드를 수정해 보겠습니다:

;(function(root) { let parent = document.querySelector(root); let div1 = parent.querySelector('#div1'); let div2 = parent.querySelector('#div2'); let div3 = parent.querySelector('#div3'); let res = parent.querySelector('#res'); let btn = parent.querySelector('#btn'); btn.addEventListener('click', function() { let num1 = Number(div1.textContent); let num2 = Number(div2.textContent); let num3 = Number(div3.textContent); res.textContent = num1 + num2 + num3; }); })('#parent');

이렇게 하면 부모 요소를 외부에서 모듈에 전달하여 쉽게 변경할 수 있게 됩니다. 반면 자식 요소들은 모듈의 내부 문제가 됩니다.

한국어
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақКыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
우리는 웹사이트 운영, 분석 및 개인화를 위해 쿠키를 사용합니다. 데이터 처리는 개인정보 처리방침에 따라 이루어집니다.
모두 수락 설정 거부