Recently, I encountered a problem, which is how to make a circle enlarge animation. If the transform: scale is used to enlarge the circle, it will cause the circle to become thick, which will not look good, as shown in the following picture:


If you use width/height instead, the animation will look slightly distorted, as shown below:





The circle is drawn with border-radius: 50%, so when width/height increases, the radius of the circle will increase, but it will be distorted in the process. What if I use the padding to animate it, and it works the same way? One solution is to turn the animation down a bit, which looks lighter, but it’s not the ultimate solution.

I searched the Internet, also did not find a good way, some use JS dynamic calculation width/height, but in fact, the same.

Finally, I thought, could I use SVG for animation? I tried it and sure enough it worked.

The first thing I want to do is draw it in SVG. I used to do it in HTML + CSS, but now I want to change that. The following code looks like this:

<svg width="22px" height="22px">
    <circle r="8" cx="11" cy="11" fill="#fff" stroke="#2492fc"/>
</svg>
Copy the code

Circle means draw a circle centered at (11, 11) with a radius of 8px, fill it with white and stroke # 2492FC. If you set fill=” None “, the fill color will be transparent. I believe many of you are unfamiliar with SVG, so LET me give you a brief introduction. In addition to circle, other commonly used drawing tag elements are shown below:


There is also a path to draw paths, as shown below:


This is done using an online SVG drawing tool, which displays the SVG code. The bezier curve can be used in path, which is a very common curve, and is also used in CSS animation to control the animation speed:


Bessel curve (third order) is based on four points to draw a smooth curve, this vector curve drawing method has great significance in graphics.

So much for the basic elements of SVG, what about animations? We should animate the radius, as shown below, using the animate tag:


The begin of the beginning of the specified animation timing, can be indefinite for infinite loops, or specify the specific number of seconds, or after a certain animation, could also be an event, such as mouseover/click/mouseout used above mouseover, namely hover, The radius changes from small to large. If you want the mouse to move back, you can add another amimate, as shown in the following code:

<svg width="22px" height="22px"> <circle r="8" cx="11" cy="11" fill="#fff" stroke="#2492fc"> <animate attributeName="r" From ="8" to="10" dur="0.3s" begin="mouseover" fill="freeze" class="magnify"/> <animate attributeName="r" from="10" To ="8" dur="0.3 "begin="mouseout" fill="freeze" class="shrink"/> </circle> </ SVG >Copy the code

If you want JS control, you can get the animate element and start the animation with its beginElement method, as shown in the following code:

If (checked) {$("animate.magnify").beginElement(); Else {$(" inanimate. Shrink ").beginElement(); }Copy the code

This makes the animation look much more elegant, as shown below:


You can also use CSS animation to control SVG animation.

This is just the simplest SVG animation, see the CSS Tricks tutorial for more complex effects. For example, you can animate shapes:


Or make an animation that moves along a path:


The main point of this article is to say that if you find it difficult to animate in HTML, try SVG, and a few lines of SVG will produce a smooth animation. For example, this article “Animating Border” introduces several methods to make the Border thickening animation. The author has used the border-width/outline/clip-path/linear-gradient/box-shadow, etc. In the end, the results are not very good, so it is better to do it in SVG.