Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialTyler Anderson
15,102 PointsCreating Previous button
I was messing with the entire project of playlist. However I was attempting to create a previous button for this playlist project. However I got some of it to work but not all of it. When I get to the top of the playlist and hit previous again it gives me the error play() and stop() undefined. I know there is a way to have the previous button work but not entirely sure how.
Playlist.prototype.next = function() {
this.stop();
this.nowPlayingIndex--;
if(this.nowPlayingIndex === this.songs.length) {
this.nowPlayingIndex = 0;
}
this.play();
};
2 Answers
Steven Parker
231,275 PointsDaniel's suggestion is good (but the parentheses are not necessary). Also, you might want to rename the function to match it's purpose, perhaps "last".
Personally, I prefer having the function not work at the ends rather than wrap around:
Playlist.prototype.last = function() {
if (this.nowPlayingIndex > 0) {
this.stop();
this.nowPlayingIndex--;
this.play();
}
};
If you wanted to get really fancy, anytime the index changes you could check if it's at either limit and disable the appropriate button. Of course, if you're not at a limit you'd enable the buttons.
Tyler Anderson
15,102 PointsThank you Steven! this worked perfectly. however I like your comment about not having it work at the end! What and how would you do that? it it involve in removing the current playing class?
andrasn
30,439 PointsHi, This is my solution to create Previous button:
Playlist.prototype.previous = function() {
this.stop();
this.nowPlayingIndex--;
if (this.nowPlayingIndex < 0) {
this.nowPlayingIndex = this.songs.length - 1;
this.play();
}
this.play();
};
Daniel Sokol
14,888 PointsDaniel Sokol
14,888 PointsSince the nowPlayingIndex is decreasing, try changing the 'If' statement to: