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 trial

JavaScript jQuery Basics (2014) Creating a Spoiler Revealer Using append()

abhi reddy
abhi reddy
1,636 Points

Can you help me with these

//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 //3.1, Show spoiler //3.2, Get rid of button

js/app.js
//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
  //3.1, Show spoiler
  //3.2, Get rid of button
index.html
<!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>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>

1 Answer

First of all, your .append() method is a bit off, you need to remove the ' around the Reveal Spoiler! text so the code will look like this:

$(".spoiler").append("<button>Reveal Spoiler!</button>");

the rest is pretty straightforward. You're just changing the method.

The methods used in these tasks are .hide(), .append(), .click(), .show() and .remove(). They are all explained in the videos so you should get there by watching them.

In the task about the .click() method you'll have to assign an anonymous function inside the parenthesis like this

$("button").click(function(){
});