簡體   English   中英

如何防止我的功能在每次點擊時運行?

[英]How can I prevent my function from running on every click?

我正在嘗試使用 HTML 和 JavaScript 創建一個動態下拉列表,但每次單擊下拉列表時,我都會得到一組新的重復值。 我怎樣才能防止這種情況發生? 我寧願堅持使用 vanilla JS 和 html

 function yearsArray(num) { let years=document.getElementById("years") let year=[...Array(num+1).keys()] year.shift() year.shift() year.forEach(element => { switch (element) { case 1: years.add(new Option(element,element,true)) break; default: years.add(new Option(element,element,false)) break; } }) }
 body{ font-family: Arial, Helvetica, sans-serif; } h1{ color: gray; }
 <!DOCTYPE html> <head> <script src="script.js"></script> <link rel="stylesheet" href="style.css"> </head> <title>Simple Interest Calculator</title> <body> <div class="maindiv"> <h1>Simple Interest Calculator</h1> <form> <label for="principal">Amount</label> <input type="number" name="principal" id="principal"> <br/> <label for="rate">Interest Rate</label> <input type="range" id="rate" name="rate" min="0" max="20" step=".25"> <span id="rate_val">10.25%</span> <br/> <label for="years">No. of Years </label> <select id="years" name="years" onclick="yearsArray(20)"> <option selected value="1">1</option> </select><br/> <!-- Interest : <span id="result"></span><br/> --> <button type="submit">Compute Interest</button> </form> </div> </body> </html>

只需在頁面加載時運行該函數一次:

(您當然可以使用標記創建選項)

 function yearsArray(num) { let years = document.getElementById("years") let year = [...Array(num + 1).keys()] year.shift() year.shift() year.forEach(element => { switch (element) { case 1: years.add(new Option(element, element, true)) break; default: years.add(new Option(element, element, false)) break; } }) } yearsArray(20); //<---------- This runs the function on page load
 body { font-family: Arial, Helvetica, sans-serif; } h1 { color: gray; }
 <!DOCTYPE html> <head> <script src="script.js"></script> <link rel="stylesheet" href="style.css"> </head> <title>Simple Interest Calculator</title> <body> <div class="maindiv"> <h1>Simple Interest Calculator</h1> <form> <label for="principal">Amount</label> <input type="number" name="principal" id="principal"> <br/> <label for="rate">Interest Rate</label> <input type="range" id="rate" name="rate" min="0" max="20" step=".25"> <span id="rate_val">10.25%</span> <br/> <label for="years">No. of Years </label> <select id="years" name="years"> <option selected value="1">1</option> </select><br/> <!-- Interest : <span id="result"></span><br/> --> <button type="submit">Compute Interest</button> </form> </div> </body> </html>

弄清楚了。 將 javascript 函數添加到 body 標簽

<body onload=yearsArray(20)></body>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM