[英]How to listen multiple button clicks in javascript
我有一個 products.html 站點,其中所有產品都列在一個容器中,您可以在其中使用“添加到購物車”按鈕將它們添加到購物車。 我的網站正文看起來像這樣
<body>
<header>
<nav class="navbar">
<ul class="nav-links">
<li><a href="index.html">Front Page</a></li>
<li><a href="register.html">Register</a></li>
<li><a href="users.html">List Users</a></li>
<li><a href="products.html">List Products</a></li>
<li><a href="cart.html">Shopping Cart</a></li>
</ul>
</nav>
</header>
<main>
<h1>Products</h1>
<div id="notifications-container"></div>
<div id="products-container"></div>
</main>
<footer>
<p>Copyright © 2020 diipadaa etc etc.</p>
</footer>
<template id="product-template">
<div class="item-row">
<h3 class="product-name"></h3>
<p class="product-description"></p>
<p class="product-price"></p>
<button>Add to cart</button>
</div>
</template>
<script src="js/utils.js"></script>
<script src="js/products.js"></script>
我有多個產品,我閱讀並使用克隆方法將它們放入站點。
const baseContainer = document.querySelector('#products-container');
const productTemplate = document.querySelector('#product-template');
products.forEach(product => {
const { name, description, price, _id } = product;
const productContainer = productTemplate.content.cloneNode(true);
productContainer.querySelector('.product-name').id = `name-${_id}`;
productContainer.querySelector('.product-name').textContent = name;
productContainer.querySelector('.product-description').id = `description-${_id}`
productContainer.querySelector('.product-description').textContent = description;
productContainer.querySelector('.product-price').id = `price-${_id}`;
productContainer.querySelector('.product-price').textContent = price;
document.getElementsByTagName('button').forEach(elem => {
console.log(elem);
});
baseContainer.append(productContainer);
});
例如,如果我在網站上有 15 種產品,我怎么能聽到每個“添加到購物車”按鈕的點擊並調用一個函數。 按鈕沒有 id 或 class。 forEach 對我不起作用,所以它不承認有多個按鈕?
克隆按鈕后,您應該給它一個屬性來定義它所關聯的產品。 就像是
products.forEach(product => {
const { name, description, price, _id } = product;
const productContainer = productTemplate.content.cloneNode(true);
//add a reference to the product ID in the button
productContainer.setAttribute("data-productID", _id);
...
改變
document.getElementsByTagName('button')
到
productContainer.getElementsByTagName('button')
在您追加之前,它不存在於文檔中。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.