⊗jsPmMCPPE 500 of 505 menu

การส่งองค์ประกอบผู้ปกครองไปยังโมดูลผ่านการปิดใน JavaScript

สมมติว่าเรามีองค์ประกอบดังต่อไปนี้:

<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
เราใช้คุกกี้สำหรับการทำงานของเว็บไซต์ การวิเคราะห์ และการปรับเนื้อหาให้เหมาะสมส่วนบุคคล การประมวลผลข้อมูลเกิดขึ้นตาม นโยบายความเป็นส่วนตัว.
ยอมรับทั้งหมด ปรับแต่ง ปฏิเสธ