frontend-mentor/product-preview-card-component
2023-05-29 11:55:21 -07:00
..
images 🚚 chore: Move relevant starter files to main directory 2023-05-28 18:45:05 -07:00
public 🔨 chore: Install Vite 2023-05-28 18:07:28 -07:00
src 💄 feat: Adjust design for desktops 2023-05-28 21:44:14 -07:00
starter 🚚 chore: Move relevant starter files to main directory 2023-05-28 18:45:05 -07:00
.gitignore 🔨 chore: Install Vite 2023-05-28 18:07:28 -07:00
index.html 💄 feat: ProductCard-addToCart 2023-05-28 21:27:20 -07:00
package-lock.json 🔨 chore: Vite + Valet 2023-05-28 18:44:18 -07:00
package.json 🔨 chore: Vite + Valet 2023-05-28 18:44:18 -07:00
README.md 📝 docs: Update README 2023-05-29 11:55:21 -07:00
tsconfig.json 🔨 chore: Vite + Valet 2023-05-28 18:44:18 -07:00
vite.config.ts 🔨 chore: Vite + Valet 2023-05-28 18:44:18 -07:00

Frontend Mentor - Product preview card component solution

This is a solution to the Product preview card component challenge on Frontend Mentor. Frontend Mentor challenges help you improve your coding skills by building realistic projects.

Table of contents

Overview

The challenge

Users should be able to:

  • View the optimal layout depending on their device's screen size
  • See hover and focus states for interactive elements

Screenshot

My process

Built with

  • CSS/HTML
  • Vite.js

What I learned

How to use a <picture> element and set images differently based on media queries:


<picture>
  <source media="(max-width: 999px)" srcset="images/image-product-mobile.jpg">
  <source media="(min-width: 1000px)" srcset="images/image-product-desktop.jpg">
  <!-- <img> is required! Src is set to fallback img -->
  <img
    src="images/image-product-desktop.jpg"
    alt="Gabrielle Essence perfume bottle"
    class="ProductCard-picture"
  >
</picture>

Additionally, does not automatically shrink-wrap to its , so CSS is required to keep from creating extra spacing:

.ProductCard-picture {
    height: 100%;
}

Useful resources

SUIT CSS

I've known about BEM for a long time, and more recently came across SUIT CSS. For a while I've used a sort of hybrid, as I liked the spacing of BEM's syntax (block__elem vs block-elem), but prefer SUIT's seperation of modifier & state. For this project though, I decided to try conforming fully to SUIT and found I actually really liked it.

Author

Note: Delete this note and add/remove/edit lines above based on what links you'd like to share.