【发布时间】:2020-11-22 01:30:33
【问题描述】:
我是 Javascript 新手,我尝试为每张卡片上的每个按钮添加一个事件侦听器,但代码使最后一张卡片(按钮)只有事件“点击”,所以有什么方法可以让它发生内部HTML卡片 这是代码:
let tracksRender = (track) => {
track.forEach(element => {
//this the card that will add the button for
let card = `<div class="card">
<div class="image">
<img class="image_img" src="${element.artwork_url || 'http://lorempixel.com/100/100/abstract/'}">
</div >
<div class="content">
<div class="header">
<a href="${element.permalink_url}" target="_blank">${element.title}</a>
</div>
</div>
</div >`;
//here i add the card to DOM
let searchResults = document.querySelector('.js-search-results');
searchResults.innerHTML += card;
// store the content of the button
let inBtn = `<i class="add icon"></i>
<span>Add to playlist</span>`;
// created button container
let btn = document.createElement("div");
btn.classList.add("ui", "bottom", "attached", "button", "js-button");
// added the content of the button
btn.innerHTML += inBtn;
// here i add the the event Listener to the button
btn.addEventListener('click', () => {
console.log("click");
});
//here i add the button to the last card have been created
searchResults.querySelector(".card:last-child").append(btn);
});
}
和结构:
<!doctype html>
<html>
<head>
<meta charset='utf-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<title>SoundCloud Player</title>
<link rel='stylesheet' href='https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.4.1/semantic.min.css'>
<link rel='stylesheet' href='styles/main.css'>
<style></style>
</head>
<body id="soundcloud-player">
<div class="ui container col">
<div class="col">
<div class="main">
<div class="js-search-results search-results ui cards">
</div>
</div>
</div>
</div>
<script src="https://connect.soundcloud.com/sdk/sdk-3.3.2.js"></script>
<script src='https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.4.1/semantic.min.js'></script>
<script src="javascript/main.js"></script>
</body>
</html>
小提琴:https://jsfiddle.net/y73bstju/7/
但它只会将事件添加到最后一张卡片
【问题讨论】:
-
你可以为你的问题创建一个 Fiddle 吗?谢谢。
-
@LajosArpad 对不起,我不明白。
-
有一个名为 jsfiddle.net 的网站,您可以在其中为您的问题创建一个最小的可重现示例。然后我们可以访问它并查看问题所在,这将使解决问题变得容易得多。
-
@LajosArpad 这是链接 (jsfiddle.net/y73bstju/7),谢谢
标签: javascript html dom addeventlistener