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 JavaScript Basics (Retired) Making Decisions with Conditional Statements Super Conditional Challenge

Alexis Pareja
Alexis Pareja
3,402 Points

Tips to fix script in super conditional challenge.

I've tried various variations with || and && while adjusting the "else ifs" but I am stuck and can not properly test the money and today variables.

script.js
var money = 9;
var today = 'Friday'

if ( money >= 100 || today === 'Friday' ) {
  alert("Time to go to the theater");    
} else if ( money >= 50 || today === 'Friday' ) {
  alert("Time for a movie and dinner");    
} else if ( money > 10 || today === 'Friday' ) {
  alert("Time for a movie");   
} else if ( today === 'Friday' ) {
  alert("It's Friday, but I don't have enough money to go out");   
} else {
  alert("This isn't Friday. I need to stay home.");
}
index.html
<!DOCTYPE HTML>
<html>
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <title>JavaScript Basics</title>
</head>
<body>
<script src="script.js"></script>
</body>
</html>

2 Answers

Andreas Nyström
Andreas Nyström
8,887 Points
var money = 9;
var today = 'Friday'

// This says: if money is greater or equal to 100 OR if today is friday. This should be && so it says. money is greater or equal to 100 AND today is friday.
if ( money >= 100 || today === 'Friday' ) {
  alert("Time to go to the theater");    
} 
// Same thing here, it says OR and not AND.
else if ( money >= 50 || today === 'Friday' ) {
  alert("Time for a movie and dinner");    
} 
// Same thing here, it says OR and not AND. 
else if ( money > 10 || today === 'Friday' ) {
  alert("Time for a movie");   
} 
// This just checks if today is friday, which it is. So try doing && on the three first statements.
else if ( today === 'Friday' ) {
  alert("It's Friday, but I don't have enough money to go out");   
} else {
  alert("This isn't Friday. I need to stay home.");
}

I can't check it myself but it should probably be something like this:

var money = 9;
var today = 'Friday'

if ( money >= 100 && today === 'Friday' ) {
  alert("Time to go to the theater");    
} else if ( money >= 50 && today === 'Friday' ) {
  alert("Time for a movie and dinner");    
} else if ( money > 10 && today === 'Friday' ) {
  alert("Time for a movie");   
} else if ( today === 'Friday' ) {
  alert("It's Friday, but I don't have enough money to go out");   
} else {
  alert("This isn't Friday. I need to stay home.");
}
Alexis Pareja
Alexis Pareja
3,402 Points

Thanks for there help!! I was on the right track but overlooked some of the other corrections with the && code.