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 trialDavid Hoffman
12,707 PointsConditional statements help needed.
Ok so here is my task: There are three list items in the index.html file. We want to be able to enter a 0, 1 or 2 in the text field to embolden the list item with the corresponding index. Can you figure out what condition to put into the if statement to make this code work? I guess that I am just having a complete mind bend. Any help would be much appreciated.
const laws = document.getElementsByTagName('li');
const indexText = document.getElementById('boldIndex');
const button = document.getElementById('embolden');
button.addEventListener('click', (e) => {
const index = parseInt(indexText.value, 10);
for (let i = 0; i < laws.length; i += 1) {
let law = laws[i];
// replace 'false' with a correct test condition on the line below
if (law.indexOf) {
law.style.fontWeight = 'bold';
} else {
law.style.fontWeight = 'normal';
}
}
});
<!DOCTYPE html>
<html>
<head>
<title>Newton's Laws</title>
</head>
<body>
<h1>Newton's Laws of Motion</h1>
<ul>
<li>An object in motion tends to stay in motion, unless acted on by an outside force.</li>
<li>Acceleration is dependent on the forces acting upon an object and the mass of the object.</li>
<li>For every action, there is an equal and opposite reaction.</li>
</ul>
<input type="text" id="boldIndex">
<button id="embolden">Embolden</button>
<script src="app.js"></script>
</body>
</html>
2 Answers
Steven Parker
231,248 PointsYou need a complete conditional expression.
And don't over-think it. All you need there is to test if the current loop index is the same as the value that was entered. And the provided code has already converted the entry into a numeric value for you.
David Hoffman
12,707 PointsThank you very much. I was overthinking that way to much.
David Hoffman
12,707 PointsDavid Hoffman
12,707 PointsThat is exactly what I thought when I first tried the challenge. This is what I first entered; if (index === laws[i]) { It tells me that this is incorrect.
Steven Parker
231,248 PointsSteven Parker
231,248 PointsYou don't want to compare the numeric value of the input to the element at index "i", you just want to compare it with the index itself.