Create fancy card with animated gradient border

Patricia Arquette
Release: 2024-10-21 14:42:02
Original
891 people have browsed it

In this tutorial, I'll walk you through creating an animated gradient border effect using CSS custom properties, which can add a dynamic and eye-catching look to your UI components. By the end, you'll have a simple card with an animated gradient border, using css custom @property.

If you are are not familiar with css custom @property read this blog first.

Basic card structure

We will be using react for this tutorial, the basic card will look like this

import "./styles.css";

const CardAnimatedBorder = () => {
  return (
    <div className="container">
      <div className="card">This is a card with animated gradient border</div>
    </div>
  );
};

export default CardAnimatedBorder;
Copy after login

Adding basic styles to the card

.container {
  width: 100%;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card {
  margin: 0 auto;
  padding: 2em;
  width: 300px;
  background: #1c1f2b;
  text-align: center;
  border-radius: 10px;
  color: #ffffff;
  position: relative;
}
Copy after login

Creating a simple border

Before creating a gradient animated border let's see how to create a simple border. We will not use the css border property but instead use pseudo elements ::before and ::after for the card. Another important property here is inset which allows us to place the pseudo elements inside the card. The z-index will be -1 as we want the border to be below the card content.

.card::after,
.card::before {
  content: "";
  position: absolute;
  background: red;
  inset: -4px;
  z-index: -1;
  border-radius: 10px;
}
Copy after login

Our card now looks like this

Create fancy card with animated gradient border

Adding custom property --angle

We will add a custom property to track the angle of the gradient. We will be using conic-gradient.
Add a custom property like this

@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
Copy after login

and make the following changes to the css

  • Replace background with background-image to display gradient.
  • Add an animation spin for the custom property angle.
  • The conic-gradient has angle as first argument and we will be changing it in order to animate.
  • Add blur and opacity for a glowing effect.

Your css should look like this

.container {
  width: 100%;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.card {
  margin: 0 auto;
  padding: 2em;
  width: 300px;
  background: #1c1f2b;
  text-align: center;
  border-radius: 10px;
  color: #ffffff;
  position: relative;
}

@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
.card::after,
.card::before {
  content: "";
  position: absolute;
  background-image: conic-gradient(
    from var(--angle),
    transparent 70%,
    blue,
    red
  );
  inset: -4px;
  z-index: -1;
  border-radius: 10px;
  animation: 2s spin linear infinite;
}

.card::before {
  filter: blur(1rem);
  opacity: 0.7;
}

@keyframes spin {
  from {
    --angle: 0deg;
  }
  to {
    --angle: 360deg;
  }
}
Copy after login

And finally we have a card with animated gradient border.

Demo

Click here

Read more

  • MDN docs @property

Original post

The above is the detailed content of Create fancy card with animated gradient border. For more information, please follow other related articles on the PHP Chinese website!

source:dev.to
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!