9th August, 2017 - 1 min. read - in Projects - Go to Index

Pssss!... Want to dive into D3.js and Dataviz?

I'll teach in a full hands-on workshop at Bigdive.

A few years ago, a little trick opened up a new trend on animations on the web. I’m talking about the Animated Line Drawing technique in SVG path discovered and documented back in 2013 by Jake Archibald here.
CSS-Tricks wrote about it extensively here.

Briefly, it relies on changing two props belonging to the SVG path, stroke-dasharray and stroke-dashoffset.
They can be set with values between 0 and the path length using the native function getTotalLength().


D3.js transition can animate those attributes out of the box, therefore, I can’t help but playing a bit with them is just a matter of these line of code:

	.attr('stroke-dasharray', function () {
		var length = this.getTotalLength()
		return Math.random() * length
  	.attr('stroke-dashoffset', function () {
		var length = this.getTotalLength()
		return Math.random() * length

I got curious about exploiting the technique to build animated structures using different shapes and pattern.

Here with horizontal lines (click to change):

Here with the border of a rect (click to change):

The border of circles (click to change):

Tha same as above with different stroke width (click to change):

Now you can experience the final exploration.

If you are interested, you can find the source code here.

Send anonymous and private messages:


Want to ask something? Drop me a line!

Not ready to talk? Follow me on Twitter.

Spotted a typo or (likely) a grammar error? Send a pull request.