A Quick CSS Guide: Crafting Neon Buttons with Glow Effects & Animations

Written by zellwk | Published 2023/12/27
Tech Story Tags: css | ui-effects | neon-buttons-in-css | css-filters | button-design | web-design | front-end | user-interface

TLDRvia the TL;DR App

When I was building the Magical Dev School website, I accidentally stumbled on a way to make Neon buttons look good.

https://youtu.be/uiI7eEUFbc4?embedable=true

There are three important elements:

1. A little bit of glow around the text

2. A larger glow around the button

3. A nice zoom effect

Making the text glow

The trick here is to use `drop-shadow` instead of `text-shadow` to create the glow effect.

`drop-shadow` works better because it creates a softer and more enveloping blur - very much like how a soft light source would fall into its surroundings.

`text-shadow` is too harsh.

We only want to use `drop-shadow` on the text, so we need to change the markup a little bit to include an extra span element.

html 
<button>
  <span class="text">Text goes here </span>
</button>

And we can include the `drop-shadow` like this:

css
.text {
  filter: drop-shadow(0 0 1px currentcolor);
}

Making the larger glow around the button

We can make a larger glow around the button with `drop-shadow` and `box-shadow`. In this case, I prefer `box-shadow` over `drop-shadow` because I can control the spread.

This lets me cast a harsher shadow that accentuates the border.

The code for `drop-shadow` is simpler because you can attach it directly to the button.

css
button {
  filter: drop-shadow(0 0 1rem var(--purple-300));
}

The code for `box-shadow` is slightly harder because you'll have to use a pseudo-element to make smooth animation. That's because transitioning `box-shadow` creates jank.

css
button {
  position: relative;
  z-index: 1;
  /* ... */
}

button:after {
  content: '';
  position: absolute;
  z-index: -1;
  inset: 0;
  border-radius: inherit;
  opacity: 0.6;
  box-shadow: 0 0 1em 0.5em var(--purple-300);
}

A nice zoom effect

The third and final piece is to jell everything together with a little bit of animations.

https://youtu.be/L-89PGVLxLo?embedable=true

Here, I opted to:

- Change the `background-color`

- Change the `color`

- Make the button bigger (as if it's floating outwards)

- And make the background glow a little bit stronger by changing the `opacity`

Codepen Link

Here's Codepen for you to play around with this neon button.

https://codepen.io/zellwk/pen/poQMqvW?embedable=true

By the way, this article is originally written on my blog. Feel free to visit that if you want to have these articles delivered to your email first-hand whenever they're released! 🙂.


Also published here.


Written by zellwk | I'm just a developer who loves to share what I discovered. I primarily write at my blog and cross-post here.
Published by HackerNoon on 2023/12/27