这个循环在 AJAX 函数中生成HTML中的按钮。
for( var i = 0; i<len; i++){
var d = new Date(response[i]['date']);
dformat = [d.getDate() + '/' +
(d.getMonth()+1) + '/' +
d.getFullYear() + ' ' +
d.getHours() + ':' +
d.getMinutes()];
console.log(response[i])
var bons = "<tbody>" +
"<th>" + response[i]['id'] + "</th>" +
"<td>" + dformat + "</td>" +
"<td>" + response[i]['poids'] + "</td>" +
"<td>" + response[i]['origine'] + "</td>" +
"<td>" + response[i]['type'] + "</td>" +
"<td>" + response[i]['famille'] + "</td>"
if(response[i]['localisation'] != "Expédié"){
bons = bons + "<td> <input class='evacuate' id='" + response[i]['id'] + "' type='button'" + "value='Evacuer'> </td>"
}else{
bons = bons + "<td>" + response[i]['localisation'] + "</td>"
}
bons = bons + "</tr>" +
"</tbody>"
$("#index").append(
bons
);
}
然后,我有另一个 AJAX 函数,使每个按钮以前生成的点击像:
$(".evacuate").on('click', function(){
console.log("test des boutons")
});
问题是,console.log没有显示,就好像这个函数从来没有被调用过一样。
3条答案
按热度按时间ldioqlga1#
试试这个:
yxyvkwin2#
您应该在页面上已经存在的元素上定义click事件。因此,对于您的情况,请选择父元素,然后添加click事件。例如,如果具有
evacuate
类的元素位于具有someclass
类的元素内部,则可以执行以下操作:根据您的代码,可以使用
tbody
标记作为父标记:gzszwxb43#
我真的不明白这是如何工作的,但感谢上面给出的答案,我设法显示我的console.log.
});