parent
480f94030e
commit
8cfc31392b
@ -1,36 +1,41 @@ |
|||||||
# Stoplight Exercise |
# Stoplight Exercise |
||||||
|
|
||||||
As always, fork and clone this repo. Submit a Pull Request when you are done. |
As always, fork and clone this repo. |
||||||
|
|
||||||
## Stoplight |
data:image/s3,"s3://crabby-images/e860c/e860c64c565ffffbcfc825e9df962017477522c5" alt="Screenshot of the stop bulb lit up" |
||||||
|
|
||||||
#### Challenge One: Button Click |
#### Part 1 |
||||||
|
|
||||||
Wire up the controls to the left of the stoplight so that when a button is clicked, the corresponding bulb will turn on and all others will turn off. |
Add JavaScript DOM event listeners to toggle the on/off state of three bulbs. |
||||||
|
|
||||||
#### Challenge Two: Button Toggle |
- When a user clicks on the "Stop" button, the top bulb should turn `red`. |
||||||
|
- When a user clicks on the "Slow" button, the middle bulb should turn `orange`. |
||||||
|
- When a user clicks on the "Go" button, the bottom bulb should turn `green`. |
||||||
|
|
||||||
Alter your event listeners to toggle the on/off state of each bulb. All three bulbs can be on or off from now on. |
**TIP**: All three bulbs can be on/off independently of one another. |
||||||
|
|
||||||
#### Challenge Three: Group "Hover" Handler |
##### Resources |
||||||
|
|
||||||
* Keep your existing code, but add new event listeners on each of your buttons that log `"Entered <textContent> button"` when a user mouses over a button. |
- [MDN - `Document.querySelector()`](https://developer.mozilla.org/en-US/docs/Web/API/Document/querySelector) |
||||||
|
- [MDN - `EventTarget.addEventListener()`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener) |
||||||
|
- [MDN - `click`](https://developer.mozilla.org/en-US/docs/Web/Events/click) |
||||||
|
- [MDN - `background-color`](https://developer.mozilla.org/en-US/docs/Web/CSS/background-color) |
||||||
|
|
||||||
* Add new event listeners on each of your buttons that log `"Left <textContent> button"` when a user mouses out. |
#### Part 2 |
||||||
|
|
||||||
* Add a single event listener on all three buttons as a group. In your group event handler, log the `textContent` of each button when a user clicks the button. |
Add new event listeners to log the mouse state of each button. |
||||||
|
|
||||||
#### Bonus Challenge: On/Off Message |
- When a user's mouse "enters" a button, log `"Entered <textContent> button"` to the console. |
||||||
|
- When a user's mouse "leaves" a button, log `"Left <textContent> button"` to the console. |
||||||
|
|
||||||
* If the corresponding bulb is off when a user clicks a button, change the log message in your group event listener to say `"<textContent> bulb on"` |
##### Resources |
||||||
|
|
||||||
* If the corresponding bulb is on when a user clicks a button, change the log message in your group event listener to say `"<textContent> bulb off"` |
- [MDN - `mouseenter`](https://developer.mozilla.org/en-US/docs/Web/Events/mouseenter) |
||||||
|
- [MDN - `mouseleave`](https://developer.mozilla.org/en-US/docs/Web/Events/mouseleave) |
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/e860c/e860c64c565ffffbcfc825e9df962017477522c5" alt="Screenshot of the stop bulb lit up" |
#### Bonus |
||||||
|
|
||||||
## Hints |
Add **one** new event listener to log the state of each bulb. |
||||||
|
|
||||||
* Retrieve a DOMElement with [`document.querySelector`](https://developer.mozilla.org/en-US/docs/Web/API/Document/querySelector) or similar method |
- When a user clicks a button that just turned on, log`"<textContent> bulb on"` to the console. |
||||||
* Attach event listeners with [`addEventListener`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener) |
- When a user clicks a button that just turned off, log`"<textContent> bulb off"` to the console. |
||||||
* Set the color of a bulb with [`background-color`](https://developer.mozilla.org/en-US/docs/Web/CSS/background-color) |
|
||||||
* Explore the various options of [`MouseEvent`](https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent) |
|
||||||
|
Loading…
Reference in new issue