Just about every other website I visit has waves patterns. I have no doubt you've seen them, too, used as dividers between content sections or a subtle background texture. The idea is they add a fluid, non-linear flair to a web design rather than relying on crisp, solid lines between elements.
Gallery of examples
- [need several more]
Waves are a neat pattern! And creating them is pretty darn easy, thanks to the gazillion online generators you can use to spit out SVG you to add directly to your HTML. Here are just a few of them:
Those are great, so use them! At the same time, I think it's a good idea to know how to make something like waves from scratch because it helps us understand the code we're using.
And there's more than one way to make waves! 🌊
The idea here is make a very large circular shape and position it off the page so only part of it is revealed:
Repeat the element for more waves:
This certainly works, but you may already see its limitations. For example, we need to know how many ways there are and then use some magic numbers to position everything.
Maybe we could do something with CSS Grid's
auto-fit powers so the number of items is less important:
Eh, still not the best. What makes this approach so tough is that putting two circles together doesn't really create a wave pattern. So, I'd say
border-radius is great when we're working with a single shape.
Yeah! We can totally chain some gradients together with various opacities to make wavey patterns. In fact, Lea Verou's classic "CSS3 Patterns Gallery" offers a perfect example using a combination of linear and radial gradients:
mask you can create creative waves and how to look into them.
This example shows you what exactly you can create with clip-path.
This is a way to create waves using clip-path and below is an example of adding creativity with CSS animations.
clip-path is not the flexible way to create waves you have to put every pixel or dot but you can create and do amazing work using it. Now there's another way to create waves which super amazing and easy. Let's look into it.
We also have SVG! What I like about this approach is that the SVG can form the shape:
Then we have all the flexibility in the world to fill the waves in with whatever color we want in CSS:
Or we can drop in a bunch of SVGs and use absolute positioning on them to get a real splashy:
We can also use SVG as a background image:
All we have to do to get multiple waves with the background image approach is to repeat the element a few times in the HTML, then reach for
background-position-x to space them apart and
opacity to show the layers:
And, of course, we can animate those as well. We tweak the
animation-duration of each wave to offset things a bit:
There you go, a bunch of ways to make waves! We looked at a bunch of different wave patterns and several approaches for coding them in CSS and SVG. Which approach is best? It really depends on the design and use case, so choose what fits best with your requirements.