Tell us what’s happening:
You should join the array returned by the instrumentCards function. Do not modify your event listener.
Your code so far
<!-- file: index.html -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Music Instruments product page</title>
<link rel="stylesheet" href="./file.css" />
</head>
<body>
<h1>Student Instruments</h1>
<main>
<select class="select-container">
<option id="all" value="all">All</option>
<option id="woodwinds" value="woodwinds">Woodwinds</option>
<option id="brass" value="brass">Brass</option>
<option id="percussion" value="percussion">Percussion</option>
</select>
<div class="products-container">
<div class="card">
<h2>Flute</h2>
<p>$500</p>
</div>
<div class="card">
<h2>Clarinet</h2>
<p>$200</p>
</div>
<div class="card">
<h2>Oboe</h2>
<p>$4000</p>
</div>
<div class="card">
<h2>Trumpet</h2>
<p>$200</p>
</div>
<div class="card">
<h2>Trombone</h2>
<p>$300</p>
</div>
<div class="card">
<h2>French Horn</h2>
<p>$4300</p>
</div>
<div class="card">
<h2>Drum Set</h2>
<p>$500</p>
</div>
<div class="card">
<h2>Xylophone</h2>
<p>$3000</p>
</div>
<div class="card">
<h2>Cymbals</h2>
<p>$200</p>
</div>
<div class="card">
<h2>Marimba</h2>
<p>$3000</p>
</div>
</div>
</main>
<script src="./file.js"></script>
</body>
</html>
/* file: styles.css */
*,
*::before,
*::after {
margin: 0;
padding: 0;
box-sizing: border-box;
}
:root {
--dark-grey: #0a0a23;
--white: #ffffff;
--yellow: #f1be32;
}
body {
background-color: var(--dark-grey);
color: var(--white);
}
h1 {
text-align: center;
margin-top: 20px;
}
.select-container {
display: block;
margin: 25px auto;
padding: 8px;
border: 4px solid var(--white);
border-radius: 4px;
width: 200px;
}
.products-container {
display: flex;
flex-direction: column;
flex-wrap: wrap;
align-items: center;
justify-content: center;
gap: 20px;
}
@media (min-width: 760px) {
.products-container {
flex-direction: row;
}
}
.card {
background-color: var(--white);
color: var(--dark-grey);
border: 4px solid var(--yellow);
border-radius: 5px;
padding: 10px;
width: 200px;
}
/* file: script.js */
// User Editable Region
/* file: script.js */
// User Editable Region
function instrumentCards(instrumentCategory) {
const instruments =
instrumentCategory === "all"
? instrumentsArr
: instrumentsArr.filter(
({ category }) => category === instrumentCategory
);
return instruments
.map(({ instrument, price }) => `
<div class="card">
<h2>${instrument}</h2>
<p>$${price}</p>
</div>
`)
.join('');
}
// User Editable Region
// User Editable Region
Your browser information:
User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:147.0) Gecko/20100101 Firefox/147.0
Challenge Information:
Build a Music Instrument Filter - Step 14