为什么 addEventListener 属性 对动态 HTMLcollection 对象不起作用?

Why does the addEventListener property does not work on a dynamic HTMLcollection object?

我正在开发 chrome 扩展并尝试将事件侦听器添加到 getElementsByClassName 变量,其中使用模板字符串动态添加元素。

我尝试了很多代码更改,但代码不起作用。

代码应该从数组“recipeList”中删除目标元素,将数组存储在 localStorage 中,然后再次使用模板字符串将更新后的数组“recipeList”呈现给 HTML 代码。

删除按钮功能

let delBtn = document.getElementsByClassName("del-btn");

for(let i = 0; i < delBtn.length; i++) { 
    delBtn[i].addEventListener("click", function() {
        recipeList.splice(i, 1);
        localStorage.setItem("recipeList", JSON.stringify(recipeList));
        recipeList = JSON.parse(localStorage.getItem("recipeList"));
        render(recipeList);
        if(!recipeList.length) {
            tabBtn.style.width = "100%";
            delAllBtn.style.display = "none";
        }
    }); 
}

渲染代码

function render(list) {
    let recipeURL = "";
    for(let i = 0; i < list.length; i++) {
        recipeURL += `
        <div class="mb-2 row">
            <div class="col-1 num-btn">
                ${i+1}
            </div>
            <div class="col-10">
                <div class="recipe-url">
                    <a target="_blank" href="${list[i]}">
                        ${list[i]}
                    </a>
                </div>
            </div>
            <div class="col-1 del-btn">
                <a href="#">
                    <i class="bi bi-trash-fill"></i>
                </a>
            </div>
        </div>
        `
    }
    urlList.innerHTML = recipeURL;
    console.log(delBtn);
}

渲染时,您会创建新的 .del-btn,它不包含在您的第一个 let delBtn = document.getElementsByClassName("del-btn"); 中。

每次创建新的 .del-btn 时,您还应该添加一个新的侦听器。

function render(list) {
    let recipeURL = "";
    for(let i = 0; i < list.length; i++) {
        recipeURL += `
        <div class="mb-2 row">
            <div class="col-1 num-btn">
                ${i+1}
            </div>
            <div class="col-10">
                <div class="recipe-url">
                    <a target="_blank" href="${list[i]}">
                        ${list[i]}
                    </a>
                </div>
            </div>
            <div class="col-1 del-btn">
                <a href="#">
                    <i class="bi bi-trash-fill"></i>
                </a>
            </div>
        </div>
        `
    }
    urlList.innerHTML = recipeURL;
    console.log(delBtn);

    Array.from(urlList.querySelectorAll('.del-btn')).forEach((btn, i) => {
        btn.addEventListener('click', () => console.log('.del-btn index: ' + i))
    })
    }
}