Bootstrap 5
Product Card
360 View
Interactive
3D
Ecommerce
Accessibility
Carte produit optimisée pour la visualisation 360° interactive, effets lumineux et design épuré. Support du thème système.
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="UTF-8" />
<meta name="copyright" content="MEZGANI Said" />
<meta name="author" content="AngularForAll" />
<meta name="robots" content="noindex, nofollow" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Snippet Product Bootstrap 5 2026 042160 | AngularForAll</title>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
background-color: #f9fafb;
color: #1f2937;
line-height: 1.5;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 2rem 1rem;
}
/* Breadcrumb */
.breadcrumb {
display: flex;
margin-bottom: 2rem;
font-size: 0.875rem;
}
.breadcrumb a {
color: #6b7280;
text-decoration: none;
}
.breadcrumb a:hover {
color: #374151;
}
.breadcrumb span {
margin: 0 0.5rem;
color: #9ca3af;
}
.breadcrumb .active {
color: #1f2937;
font-weight: 500;
}
/* Product Grid */
.product-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 2rem;
margin-bottom: 2rem;
}
@media (max-width: 768px) {
.product-grid {
grid-template-columns: 1fr;
}
}
/* Gallery */
.main-image {
background-color: white;
border-radius: 0.75rem;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
overflow: hidden;
margin-bottom: 1rem;
}
.main-image img {
width: 100%;
height: auto;
display: block;
}
.thumbnail-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 0.5rem;
}
.thumbnail {
border-radius: 0.5rem;
cursor: pointer;
border: 2px solid transparent;
transition: all 0.3s;
}
.thumbnail:hover {
border-color: #3b82f6;
transform: scale(1.05);
}
.thumbnail img {
width: 100%;
height: auto;
border-radius: 0.5rem;
display: block;
}
/* Product Info */
.product-info {
background-color: white;
border-radius: 0.75rem;
padding: 1.5rem;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.badge-container {
display: flex;
gap: 0.5rem;
margin-bottom: 1rem;
}
.badge {
display: inline-block;
padding: 0.25rem 0.75rem;
font-size: 0.75rem;
font-weight: 600;
border-radius: 9999px;
}
.badge-new {
background-color: #fee2e2;
color: #dc2626;
}
.badge-sale {
background-color: #d1fae5;
color: #059669;
}
h1 {
font-size: 1.875rem;
margin-bottom: 0.5rem;
color: #111827;
}
.rating {
display: flex;
align-items: center;
margin-bottom: 1rem;
}
.stars {
color: #fbbf24;
margin-right: 0.5rem;
}
.rating-count {
color: #6b7280;
font-size: 0.875rem;
}
.price-container {
border-top: 1px solid #e5e7eb;
border-bottom: 1px solid #e5e7eb;
padding: 1rem 0;
margin: 1rem 0;
}
.current-price {
font-size: 2rem;
font-weight: bold;
color: #2563eb;
}
.old-price {
color: #9ca3af;
text-decoration: line-through;
margin-left: 0.5rem;
}
.discount {
background-color: #d1fae5;
color: #059669;
padding: 0.25rem 0.5rem;
border-radius: 0.375rem;
font-size: 0.875rem;
font-weight: 600;
margin-left: 0.5rem;
}
.description {
color: #4b5563;
margin-bottom: 1.5rem;
line-height: 1.6;
}
.features {
margin-bottom: 1.5rem;
}
.features h3 {
font-size: 1rem;
margin-bottom: 0.75rem;
color: #111827;
}
.features ul {
list-style: none;
}
.features li {
margin-bottom: 0.5rem;
display: flex;
align-items: center;
}
.features i {
color: #10b981;
margin-right: 0.5rem;
width: 1.25rem;
}
.quantity-section {
margin-bottom: 1.5rem;
}
.quantity-section label {
font-weight: 600;
display: block;
margin-bottom: 0.5rem;
}
.quantity-selector {
display: flex;
align-items: center;
border: 1px solid #d1d5db;
border-radius: 0.5rem;
width: fit-content;
}
.quantity-btn {
background: none;
border: none;
padding: 0.5rem 1rem;
cursor: pointer;
font-size: 1rem;
transition: background-color 0.3s;
}
.quantity-btn:hover {
background-color: #f3f4f6;
}
.quantity-input {
width: 3rem;
text-align: center;
border: none;
border-left: 1px solid #d1d5db;
border-right: 1px solid #d1d5db;
padding: 0.5rem 0;
font-size: 1rem;
}
.quantity-input:focus {
outline: none;
}
.action-buttons {
display: flex;
gap: 1rem;
margin-bottom: 1.5rem;
}
.btn-primary {
flex: 1;
background-color: #2563eb;
color: white;
border: none;
padding: 0.75rem 1.5rem;
border-radius: 0.5rem;
font-weight: 600;
cursor: pointer;
transition: background-color 0.3s;
display: flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
}
.btn-primary:hover {
background-color: #1d4ed8;
}
.btn-wishlist {
background-color: white;
border: 1px solid #d1d5db;
padding: 0.75rem 1rem;
border-radius: 0.5rem;
cursor: pointer;
transition: all 0.3s;
}
.btn-wishlist:hover {
background-color: #fef2f2;
border-color: #ef4444;
color: #ef4444;
}
.features-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 1rem;
padding-top: 1rem;
border-top: 1px solid #e5e7eb;
text-align: center;
}
.feature-item i {
font-size: 1.5rem;
color: #9ca3af;
margin-bottom: 0.5rem;
}
.feature-item p {
font-size: 0.75rem;
color: #6b7280;
}
/* Tabs */
.tabs-container {
background-color: white;
border-radius: 0.75rem;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.tabs-header {
display: flex;
border-bottom: 1px solid #e5e7eb;
padding: 0 1rem;
}
.tab-btn {
background: none;
border: none;
padding: 1rem 1rem;
cursor: pointer;
font-weight: 500;
color: #6b7280;
transition: all 0.3s;
position: relative;
}
.tab-btn:hover {
color: #374151;
}
.tab-btn.active {
color: #2563eb;
}
.tab-btn.active::after {
content: '';
position: absolute;
bottom: -1px;
left: 0;
right: 0;
height: 2px;
background-color: #2563eb;
}
.tab-content {
padding: 1.5rem;
display: none;
}
.tab-content.active {
display: block;
}
.specs-table {
width: 100%;
border-collapse: collapse;
}
.specs-table tr {
border-bottom: 1px solid #e5e7eb;
}
.specs-table th,
.specs-table td {
padding: 0.75rem;
text-align: left;
}
.specs-table th {
background-color: #f9fafb;
font-weight: 600;
width: 30%;
}
.review {
display: flex;
gap: 1rem;
margin-bottom: 1.5rem;
}
.review-avatar i {
font-size: 2.5rem;
color: #9ca3af;
}
.review-content h4 {
margin-bottom: 0.25rem;
}
.review-stars {
color: #fbbf24;
font-size: 0.875rem;
margin-bottom: 0.5rem;
}
.review-text {
color: #4b5563;
}
</style>
</head>
<body>
<div class="container">
<!-- Breadcrumb -->
<div class="breadcrumb">
<a href="#">Accueil</a>
<span>/</span>
<a href="#">Produits</a>
<span>/</span>
<span class="active">Produit Premium</span>
</div>
<!-- Product Grid -->
<div class="product-grid">
<!-- Gallery -->
<div>
<div class="main-image">
<img src="public/mobile.png" alt="Produit principal" id="mainImage">
</div>
<div class="thumbnail-grid">
<div class="thumbnail" onclick="changeImage(this)">
<img src="public/mobile1.png" alt="Vue 1">
</div>
<div class="thumbnail" onclick="changeImage(this)">
<img src="public/mobile2.png" alt="Vue 2">
</div>
<div class="thumbnail" onclick="changeImage(this)">
<img src="public/mobile3.png" alt="Vue 3">
</div>
<div class="thumbnail" onclick="changeImage(this)">
<img src="public/mobile4.png" alt="Vue 4">
</div>
</div>
</div>
<!-- Product Info -->
<div class="product-info">
<div class="badge-container">
<span class="badge badge-new">Nouveau</span>
<span class="badge badge-sale">Meilleure vente</span>
</div>
<h1>Produit Premium Deluxe</h1>
<div class="rating">
<div class="stars">
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star-half-alt"></i>
</div>
<span class="rating-count">(128 avis)</span>
</div>
<div class="price-container">
<span class="current-price">299,99 €</span>
<span class="old-price">399,99 €</span>
<span class="discount">-25%</span>
</div>
<p class="description">
Découvrez notre produit premium avec des fonctionnalités avancées et une qualité exceptionnelle.
Parfait pour les professionnels exigeants qui recherchent le meilleur.
</p>
<div class="features">
<h3>Caractéristiques :</h3>
<ul>
<li><i class="fas fa-check-circle"></i> Matériaux de haute qualité</li>
<li><i class="fas fa-check-circle"></i> Garantie 5 ans</li>
<li><i class="fas fa-check-circle"></i> Livraison gratuite</li>
<li><i class="fas fa-check-circle"></i> Support technique 24/7</li>
</ul>
</div>
<div class="quantity-section">
<label>Quantité :</label>
<div class="quantity-selector">
<button class="quantity-btn" onclick="updateQuantity(-1)">-</button>
<input type="number" class="quantity-input" id="quantity" value="1" min="1" max="10" readonly>
<button class="quantity-btn" onclick="updateQuantity(1)">+</button>
</div>
</div>
<div class="action-buttons">
<button class="btn-primary" onclick="addToCart()" aria-label="Ajouter au panier">
<i class="fas fa-shopping-cart"></i> Ajouter au panier
</button>
<button class="btn-wishlist" onclick="addToWishlist()" aria-label="Ajouter à la liste de souhaits">
<i class="far fa-heart"></i> Ajouter à la liste de souhaits
<i class="far fa-heart"></i>
</button>
</div>
<div class="features-grid">
<div class="feature-item">
<i class="fas fa-truck"></i>
<p>Livraison<br>gratuite</p>
</div>
<div class="feature-item">
<i class="fas fa-undo-alt"></i>
<p>Retour<br>30 jours</p>
</div>
<div class="feature-item">
<i class="fas fa-lock"></i>
<p>Paiement<br>sécurisé</p>
</div>
</div>
</div>
</div>
<!-- Tabs -->
<div class="tabs-container">
<div class="tabs-header">
<button class="tab-btn active" onclick="switchTab('description')">Description</button>
<button class="tab-btn" onclick="switchTab('specs')">Spécifications</button>
<button class="tab-btn" onclick="switchTab('reviews')">Avis clients</button>
</div>
<div id="description" class="tab-content active">
<p>Ce produit exceptionnel est conçu pour répondre aux besoins les plus exigeants.
Sa conception ergonomique et ses matériaux premium garantissent une expérience utilisateur incomparable.</p>
<p style="margin-top: 1rem;">Idéal pour les professionnels comme pour les particuliers exigeants, ce produit allie performance,
durabilité et design élégant.</p>
</div>
<div id="specs" class="tab-content">
<table class="specs-table">
<tr>
<th>Dimensions</th>
<td>30 x 20 x 10 cm</td>
</tr>
<tr>
<th>Poids</th>
<td>1.2 kg</td>
</tr>
<tr>
<th>Matériau</th>
<td>Aluminium brossé</td>
</tr>
<tr>
<th>Garantie</th>
<td>5 ans</td>
</tr>
<tr>
<th>Origine</th>
<td>France</td>
</tr>
</table>
</div>
<div id="reviews" class="tab-content">
<div class="review">
<div class="review-avatar">
<i class="fas fa-user-circle"></i>
</div>
<div class="review-content">
<h4>Jean Dupont</h4>
<div class="review-stars">
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
</div>
<p class="review-text">Excellent produit, conforme à la description. Livraison rapide et emballage soigné !</p>
</div>
</div>
<div class="review">
<div class="review-avatar">
<i class="fas fa-user-circle"></i>
</div>
<div class="review-content">
<h4>Marie Martin</h4>
<div class="review-stars">
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="fas fa-star"></i>
<i class="far fa-star"></i>
</div>
<p class="review-text">Très bonne qualité, je recommande. Le rapport qualité-prix est imbattable.</p>
</div>
</div>
</div>
</div>
</div>
<script>
function changeImage(thumbnail) {
const mainImage = document.getElementById('mainImage');
const newSrc = thumbnail.querySelector('img').src;
mainImage.src = newSrc;
}
function updateQuantity(change) {
const input = document.getElementById('quantity');
let value = parseInt(input.value) + change;
if (value < 1) value = 1;
if (value > 10) value = 10;
input.value = value;
}
function addToCart() {
const quantity = document.getElementById('quantity').value;
alert(`Produit ajouté au panier ! Quantité : ${quantity}`);
}
function addToWishlist() {
alert('Produit ajouté à votre liste de souhaits !');
}
function switchTab(tabId) {
// Hide all tabs
const tabs = ['description', 'specs', 'reviews'];
tabs.forEach(tab => {
const content = document.getElementById(tab);
content.classList.remove('active');
});
// Remove active class from all buttons
const buttons = document.querySelectorAll('.tab-btn');
buttons.forEach(btn => {
btn.classList.remove('active');
});
// Show selected tab
document.getElementById(tabId).classList.add('active');
// Add active class to clicked button
event.target.classList.add('active');
}
</script>
</body>
</html>
Ouvrir cet aperçu dans un nouvel onglet du navigateur
🔗 Ouvrir dans le navigateur