You can accomplish this by using "event delegation" where you set up just one handler on an element that is a common ancestor to all the select
elements you wish to handle events on. The event will originate at the select
but not be handled there and will "bubble" up to the ancestor you choose. Then you handle the event at that ancestor and use the event.target
that will be accessible in the handler to reference the actual element that triggered the event and relative DOM references to reference the p
element you need to update.
The benefit here is that you only set up one handler (which saves on memory and performance) and the code is simplified. Also, you can add new select
structures without having to alter the handling code at all.
// Set up a single handler at a common ancestor of all the select elements
document.body.addEventListener("change", function(event){
// event.target references the element that actually triggered the event
let target = event.target;
// Check to see if the event was triggered by a DOM element
// you care to handle
if(target.classList.contains("select")){
// Access the <p> element that is the previous sibling to the
// select that triggered the event and update it
target.previousElementSibling.textContent = target.value
}
});
<div>
<p class="price">$15</p>
<select class="select">
<option disabled hidden selected>size</option>
<option value="$20">40cmx40cm</option>
<option value="$30">30cmx40cm</option>
<option value="$50">50cmx50cm</option>
</select>
</div>
<div>
<p class="price">$15</p>
<select class="select">
<option disabled hidden selected>size</option>
<option value="$20">40cmx40cm</option>
<option value="$30">30cmx40cm</option>
<option value="$50">50cmx50cm</option>
</select>
</div>
<div>
<p class="price">$15</p>
<select class="select">
<option disabled hidden selected>size</option>
<option value="$20">40cmx40cm</option>
<option value="$30">30cmx40cm</option>
<option value="$50">50cmx50cm</option>
</select>
</div>
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…