You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2.8 KiB

Responsive Web Design Projects - Build a Product Landing Page

This challenge came from freeCodeCamp, which is awesome for hands-on learning of topics related to software development.


Objective: Build a app that is functionally similar to this.

Fulfill the below user stories and get all of the tests to pass. Give it your own personal style.

You can use HTML, JavaScript, and CSS to complete this project. Plain CSS is recommended because that is what the lessons have covered so far and you should get some practice with plain CSS. You can use Bootstrap or SASS if you choose. Additional technologies (just for example jQuery, React, Angular, or Vue) are not recommended for this project, and using them is at your own risk. Other projects will give you a chance to work with different technology stacks like React. We will accept and try to fix all issue reports that use the suggested technology stack for this project. Happy coding!

User stories

  1. My product landing page should have a header element with a corresponding id="header".

  2. I can see an image within the header element with a corresponding id="header-img". A company logo would make a good image here.

  3. Within the #header element I can see a nav element with a corresponding id="nav-bar".

  4. I can see at least three clickable elements inside the nav element, each with the class nav-link.

  5. When I click a .nav-link button in the nav element, I am taken to the corresponding section of the landing page.

  6. I can watch an embedded product video with id="video".

  7. My landing page has a form element with a corresponding id="form".

  8. Within the form, there is an input field with id="email" where I can enter an email address.

  9. The #email input field should have placeholder text to let the user know what the field is for.

  10. The #email input field uses HTML5 validation to confirm that the entered text is an email address.

  11. Within the form, there is a submit input with a corresponding id="submit".

  12. When I click the #submit element, the email is submitted to a static page (use this mock URL.

  13. The navbar should always be at the top of the viewport.

  14. My product landing page should have at least one media query.

  15. My product landing page should utilize CSS flexbox at least once.

You can build your project by forking this CodePen pen. Or you can use this CDN link to run the tests in any environment you like.