gpt4 book ai didi

javascript - onclick执行不起作用,仅在创建DOM时执行

转载 作者:行者123 更新时间:2023-12-03 00:54:44 25 4
gpt4 key购买 nike

我有以下 HTML 和 javascript。我可以毫无问题地创建按钮,但是单击按钮时 onclick 函数不起作用。它没有做任何事情。

如果我将该方法放在不带 ' 的情况下,它会在生成表单时执行,一个接一个地生成 3 个对话框

function makeUL(array) {
var list = document.createElement('ul');

for (var i = 0; i < array.length; i++) {
var btn = document.createElement("BUTTON");
/*
btn.onClick = function () {
buttonClicked(array[i]);
};*/

var t = document.createTextNode(array[i]); // Create a text node
btn.appendChild(t); // Append the text to <button>
btn.type = "button"
btn.onClick = 'buttonClicked()';
list.appendChild(btn); // Append <button> to <body>
var nextLine = document.createElement("td");
list.appendChild(nextLine);
}
return list;
}
/*
function buttonClicked(buttonName){
alert(buttonName);
}*/
function buttonClicked() {
alert("algo");
}

self.onInit = function() {
var boton = [];
for (var g = 0; g < self.ctx.settings.Botones.length; g++) {
boton[0] = self.ctx.settings.Botones[g].btnId;
boton[1] = self.ctx.settings.Botones[g].method;
boton[2] = self.ctx.settings.Botones[g].params;
document.getElementById('myList').appendChild(makeUL(boton));
}


self.ctx.$scope.sendCommand = function() {
var timeout = self.ctx.settings.requestTimeout;
var rpcMethod = self.ctx.settings.method;
var rpcParams = self.ctx.settings.params;

var commandPromise;
commandPromise = self.ctx.controlApi.sendTwoWayCommand(rpcMethod, rpcParams, timeout);
commandPromise.then(
function success(response) {
//alert("Comando recibido exitosamente\n Respuesta:" + angular.toJson(response));
alert("Comando recibido exitosamente");
},
function fail(rejection) {
alert("ERROR AL ENVIAR COMANDO");
}
);
};
};
<form name="rpcForm">
<md-content class="md-padding" layout="column">
<div id="myList"></div>
</md-content>
</form>

最佳答案

问题是:

btn.onClick = 'buttonClicked()';

看起来您试图分配给 HTML 的 onclick 属性,在这种情况下,正确的语法是

btn.setAttribute('onclick', 'buttonClicked()');

但是由于您已经拥有对该元素的引用,因此无需求助于属性;无论如何,内联处理程序都是非常糟糕的做法。更改为:

btn.onclick = buttonClicked;

(注意 onclick 中的小写 c),或

btn.addEventListener('click', buttonClicked);

此外,您可能会考虑简单地分配给按钮的 textContent 而不是显式创建文本节点,这样更容易读写:更改

var t = document.createTextNode(array[i]); // Create a text node
btn.appendChild(t); // Append the text to <button>

btn.textContent = array[i];

关于javascript - onclick执行不起作用,仅在创建DOM时执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52885389/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com