How to create Responsive testimonial grid?
Testimonials are an essential part of any business or service website as they help build trust and credibility with potential customers. A testimonial grid is a great way to showcase customer feedback in an organized and visually appealing manner. In this blog post, we will guide you through the process of building a responsive testimonial grid using HTML and CSS.
Create the HTML Markup
The first step is to create the HTML markup for the testimonial grid. We will use the following structure:
<div class="testimonial-grid">
<div class="testimonial">
<div class="testimonial-image">
<img src="image-1.jpg" alt="Testimonial Image">
</div>
<div class="testimonial-text">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis at velit maximus, molestie est a, tempor magna.</p>
<h4>John Doe</h4>
<span>CEO, XYZ Company</span>
</div>
</div>
<div class="testimonial">
<div class="testimonial-image">
<img src="image-2.jpg" alt="Testimonial Image">
</div>
<div class="testimonial-text">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis at velit maximus, molestie est a, tempor magna.</p>
<h4>Jane Doe</h4>
<span>Founder, ABC Company</span>
</div>
</div>
<!-- Add more testimonials as needed -->
</div>
In the above code, we have created a div
with a class of testimonial-grid
, which will act as a container for our testimonial grid. Inside this container, we have added div
elements with a class of testimonial
to represent each testimonial. Each testimonial has two child div
elements - testimonial-image
and testimonial-text
.
Style the Testimonial Grid with CSS
The next step is to style the testimonial grid with CSS. We will use flexbox to create a responsive grid that will adjust to different screen sizes. Here's the CSS code:
.testimonial-grid {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.testimonial {
width: calc(33.33% - 20px);
margin-bottom: 40px;
background-color: #fff;
border-radius: 5px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
}
.testimonial-image {
height: 100px;
overflow: hidden;
border-radius: 5px 5px 0 0;
}
.testimonial-image img {
width: 100%;
height: auto;
object-fit: cover;
}
.testimonial-text {
padding: 20px;
}
.testimonial-text p {
margin-bottom: 10px;
}
.testimonial-text h4 {
margin-bottom: 5px;
}
.testimonial-text span {
font-size: 14px;
color: #999;
}
In the above code, we have styled the testimonial-grid
container with flexbox to create a responsive grid. The justify-content: space-between
property ensures that the testimonials are evenly spaced out on the horizontal axis.
We have also styled the testimonial
class to give it a width of 33.33% minus 20px (to account for the margin), a white background, and a box shadow to make it stand out from the background.
The testimonial-image
class has a fixed height of 100px and an overflow property set to hidden
, which ensures that the image is cropped to the desired height. We have also added a border radius property to give the image a rounded corner effect.
The testimonial-image img
class ensures that the image inside the testimonial-image
div is displayed at full width and with a height of auto
, while object-fit: cover
ensures that the image is scaled to cover the full area of the container without losing its aspect ratio.
The testimonial-text
class sets a padding of 20px to the testimonial text container, and the p
, h4
, and span
elements inside are styled with appropriate margin and font sizes to make the text easy to read.
Make the Testimonial Grid Responsive
The final step is to make the testimonial grid responsive. We can do this by adding media queries that adjust the width of the testimonial elements as the screen size changes. Here's the CSS code:
@media screen and (max-width: 768px) {
.testimonial {
width: calc(50% - 20px);
}
}
@media screen and (max-width: 480px) {
.testimonial {
width: 100%;
}
}
In the above code, we have added two media queries that adjust the width of the testimonial
element as the screen size changes. On screens that are less than or equal to 768px wide, the width of the testimonial
element is set to 50% minus 20px, allowing two testimonials to fit on the same row. On screens that are less than or equal to 480px wide, the width of the testimonial
element is set to 100%, allowing one testimonial to take up the full width of the container.
And that's it! With just a few lines of HTML and CSS code, we have created a responsive testimonial grid that looks great on all screen sizes. You can customize the styling and add more testimonials as needed to make it work for your specific use case.
Here is combined code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>How to create Responsive testimonial grid?</title>
<style>
.testimonial-grid {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.testimonial {
width: calc(33.33% - 20px);
margin-bottom: 40px;
background-color: #fff;
border-radius: 5px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
}
.testimonial-image {
height: 100px;
overflow: hidden;
border-radius: 5px 5px 0 0;
}
.testimonial-image img {
width: 100%;
height: auto;
object-fit: cover;
}
.testimonial-text {
padding: 20px;
}
.testimonial-text p {
margin-bottom: 10px;
}
.testimonial-text h4 {
margin-bottom: 5px;
}
.testimonial-text span {
font-size: 14px;
color: #999;
}
@media screen and (max-width: 768px) {
.testimonial {
width: calc(50% - 20px);
}
}
@media screen and (max-width: 480px) {
.testimonial {
width: 100%;
}
}
</style>
</head>
<body>
<div class="testimonial-grid">
<div class="testimonial">
<div class="testimonial-image">
<img src="image-1.jpg" alt="Testimonial Image" />
</div>
<div class="testimonial-text">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis at velit maximus, molestie est a, tempor magna.</p>
<h4>John Doe</h4>
<span>CEO, XYZ Company</span>
</div>
</div>
<div class="testimonial">
<div class="testimonial-image">
<img src="image-2.jpg" alt="Testimonial Image" />
</div>
<div class="testimonial-text">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis at velit maximus, molestie est a, tempor magna.</p>
<h4>Jane Doe</h4>
<span>Founder, ABC Company</span>
</div>
</div>
<!-- Add more testimonials as needed -->
</div>
</body>
</html>
In summary, building a responsive testimonial grid with HTML and CSS involves creating a container element and adding testimonial elements inside. Each testimonial element contains an image, a testimonial text container, and appropriate styling to make it look good on all screen sizes. Finally, media queries are used to adjust the width of the testimonial elements as the screen size changes, ensuring that the testimonial grid remains responsive.
Testimonials are a great way to showcase your brand's credibility and build trust with potential customers. By creating a responsive testimonial grid with HTML and CSS, you can ensure that your testimonials are displayed in an attractive and user-friendly way, no matter what device your website visitors are using.
You may also like
Building a responsive testimonial grid with HTML, CSS, and JavaScript
This blog post guides readers through the process of building a resp...
Continue readingBuilding a responsive testimonial slider with HTML and CSS
In this tutorial, we learned how to build a responsive testimonial s...
Continue readingBuilding a responsive product grid with HTML and CSS
Building a responsive product grid is crucial in web development to ...
Continue reading