[英]How to pass a parameter in an onclick function?
我想使用在JavaScript中帶有參數的onclick函數。
調用button.onclick = someAction
起作用。 有沒有辦法使用帶有參數的函數呢? 例如:
function loadAPP() {
button = someButton(param);
button.onclick = someAction(param);
document.body.appendChild(button);
}
您可以使用bind
並將參數綁定到函數。
const someAction = param => console.log(param); const button = document.createElement('button'); button.onclick = someAction.bind(button,'this is my params'); document.body.appendChild(button);
我知道的最簡單的方法是將值包含在data-*
屬性中,並在click事件函數中調用它
var btn = document.getElementById("test"); btn.onclick = function(){ console.log(btn.getAttribute("data-param1")); console.log(btn.getAttribute("data-param2")); }
<button id="test" data-param1="value1" data-param2="value2"> Test </button>
標准做法是使用匿名函數 :
button.onclick = () => someAction(param);
要么
button.onclick = function() { someAction(param) };
如果您的環境不支持箭頭語法。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.