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 trialConnor Sage
9,577 PointsI am really stuck, so stuck, please help.
I need to integrate
//Prevent spoilerphobes from seeing spoilers
//Solution: Hide spoilers and reveal them through user interaction
//1, Hide spoiler
$(".spoiler span").hide();
//2, Add a button
$(".spoiler").append("<button>Reveal Spoiler!</button>");
//3, When button pressed
$("button").click(function(){
//3.1, Show spoiler
$(".spoiler span <span></span>");
//3.2, Get rid of button
$(this);
});
<!DOCTYPE html>
<html>
<head>
<title>Star Wars Spoilers</title>
<link rel="stylesheet" href="css/style.css" type="text/css" media="screen" title="no title" charset="utf-8">
</head>
<body>
<img src="img/deathstar.png" />
<p class="spoiler">
<!--Spoiler:-->
<span class="spoiler">Darth Vader is Luke Skywalker's Father! Noooooooooooo!</span>
</p>
<script src="//code.jquery.com/jquery-1.11.0.min.js" type="text/javascript" charset="utf-8"></script>
<script src="js/app.js" type="text/javascript" charset="utf-8"></script>
</body>
</html>
2 Answers
Lucas Santos
19,315 PointsYou're missing the show method and the remove method.
Should look like this:
//Prevent spoilerphobes from seeing spoilers
//Solution: Hide spoilers and reveal them through user interaction
//1, Hide spoiler
$(".spoiler span").hide();
//2, Add a button
$(".spoiler").append("<button>Reveal Spoiler!</button>");
//3, When button pressed
$("button").click(function(){
//3.1, Show spoiler
$(".spoiler span").show();
//3.2, Get rid of button
$(this).remove();
});
Joni Laukkonen
15,429 PointsYea so as stated above only issues are on the click function. I added some commenting on the lines you had issues with just in case.
So what you got now:
$("button").click(function(){
//3.1, Show spoiler
$(".spoiler span <span></span>"); // SEE CORRECT WAY BELOW
//3.2, Get rid of button
$(this); // MISSING BUTTON REMOVAL
});
So instead you'd need to have this:
$("button").click(function(){
//3.1, Show spoiler
$(".spoiler span").show(); // so first target the element .spoiler and span tag in it and use the .show() method on that
//3.2, Get rid of button
$(this).remove(); //this targets the element that triggered the function, in this case button that is clicked and then the remove() is used on that
});
Steve Brewer
15,030 PointsSteve Brewer
15,030 PointsYou just need to use .show on the spoiler class: