For this app, we will pull data from the iTunes API.
You'll use this data to pull songs based on a user search that your user performs. Here is an idea of what the end result should look like, though you can have fun with the design.
Here are the steps you'll need to take in order to complete this project.
- Build a form that has an
<input>
where a user can fill in a band or artist. - When the user types in a band or artist and presses the submit button (or presses Enter), you will make the search request.
- When your request returns, use the results to display a listing of songs related to the search term.
- When a user clicks a song in your listing, the song should play in an
<audio>
tag that you've also added to the page (see the mockup).
There will be some new concepts you'll need to work through on this project, so feel free to ask for assistance along the way.
- API documents
- Read through the documentation before getting started. Everything you'll need to know is in there.
- Playing a song
- You'll need to research the
<audio>
tag for this part - docs here - Hint: You'll need to dynamically change the
src
value
- You'll need to research the
One hard part will be getting the song to play. Since you will be dynamically generating the HTML for your results, adding an event listener to each result can be tricky. One way to make this easier is to put your click
event listener on a parent node (like a div
around the entire results section) and then get the correct item clicked on in your event listener. This is called "event delegation" and here is a comprehensive article on the technique.
Add a radio button to switch the search between artist, song title, or album title.