创建元素后无法调用函数。 jQuery

Cant call function after creating element. jQuery

所以我的目标是在点击 "li" 时 运行 一个函数,但是 li 的数量取决于用户的选择... 当我创建准确数量的 li 元素时函数工作...

$("li").click(function(){
var e = $(this).attr("id");
   alert(e);});
    
li{
 border: 1px solid black;
 cursor: pointer;
 display: inline-block;
 padding:5px 10px 5px 10px;
}
ul{
 display: inline-block;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="questlist">
  <li id='quest1'>1</li>
  <li id='quest2'>2</li>
  <li id='quest3'>3</li>
  <li id='quest4'>4</li>
  <li id='quest5'>5</li>
  <li id='quest6'>6</li>
  <li id='quest7'>7</li>
  <li id='quest8'>8</li>
  <li id='quest9'>9</li>
  <li id='quest10'>10</li>
   </ul>

但是当我想根据用户选择创建列表时,我无法 运行 功能已经尝试:

function countList(ListX){
    for(k=0;k<ListX; k++){
        ke = k+1;
        node = document.createElement("LI");
        node.setAttribute("id", "quest"+ke);
        textnode = document.createTextNode(ke);
        node.appendChild(textnode);
        document.getElementById("questlist").appendChild(node);
        }}

function countList(ListX){
  for(k=0;k<ListX; k++){
  ke = k+1;
  document.getElementById("questlist").innerHTML += "<li id='quest"+ke+"'>"+ke+"</li>";
        }}

var ListX = 10;

function countList(ListX){
    for(k=0;k<ListX; k++){
        ke = k+1;
        node = document.createElement("LI");
        node.setAttribute("id", "quest"+ke);
        textnode = document.createTextNode(ke);
        node.appendChild(textnode);
        document.getElementById("questlist").appendChild(node);
        }}

countList(ListX);

$("li").click(function(){
var e = $(this).attr("id");
   alert(e);});
li{
 border: 1px solid black;
 cursor: pointer;
 display: inline-block;
 padding:5px 10px 5px 10px;
}
ul{
 display: inline-block;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="questlist"></ul>

这两个函数都为我创建了具有预期 ID 的 "li" 元素,或者至少在我打开控制台并分析每个 "li" 元素后,我可以看到预期的 ID。 需要

像这样在 li 元素上使用 on 方法而不是点击处理程序

$('body').on('click', 'li', function() {
    var e = $(this).attr("id");
    alert(e);
});

你的其余代码没问题,只需使用上面的代码而不是 $("li").click..

工作Demo here

官方文档说:

Event handlers are bound only to the currently selected elements; they must exist at the time your code makes the call to .on()

您需要确保在附加事件时实际元素存在。因此,如果您的 li 标签在附加事件时不存在,则 .click() 方法将失败。您的下一个选择是将事件绑定到 parents 之一(在您的情况下它将是 UL 标记,如下所示:

$("#questlist").on("click", "li", function() {
    var e = $(this).attr("id");
    alert(e);
})

也从现在开始使用 .on() 方法,它将事件处理程序附加到一组选定的元素,并且它非常适合页面上存在的元素。