Preface You should often see this kind of special effect. It's very cool, isn't it? This is the most common special effect in Google So, is there any way to achieve this effect using Ideas In fact, it is an animation, a perfect circle grows from small to large, which can be easily achieved using the animation in Sample Code @keyframes ripple{ from { transform: scale(0); opacity: 1; } to { transform: scale(1); opacity: 0; } } The way to implement it with Sample Code var btn = document.getElementById('btn'); btn.addeventlistener('click',function(){ addClass(btn,'animate') },false) btn.addeventlistener('transitionend',function(){//Listen for the end of CSS3 animation removeClass(btn,'animate') },false) So how to trigger the animation through CSS? CSS Implementation The pseudo-classes that interact with the mouse in
In many cases, the effects on our pages are achieved through Let's try it first. structure This is the page structure and style we wrote <style> .btn{ display: block; width: 300px; outline: 0; overflow: hidden; position: relative; transition: .3s; cursor: pointer; user-select: none; height: 100px; text-align: center; line-height: 100px; font-size: 50px; background: tomato; color: #fff; border-radius: 10px; } </style> <a class="btn">button</a> Very simple, just an ordinary button style Next we add the perfect circle we need to the button. We use pseudo elements to achieve this .btn:after{ content: ''; position: absolute; width: 100%; padding-top: 100%; background: transparent; border-radius: 50%; left: 50%; top: 50%; transform: translate(-50%,-50%) } Let's remove Then, we write a scaling animation @keyframes ripple{ from { transform: translate(-50%,-50%) scale(0); /**Since we wrote the transformation attribute by default, we need to add translate(-50%,-50%) here, otherwise it will be replaced**/ background: rgba(0,0,0,.25); } to { transform: translate(-50%,-50%) scale(1); background: transparent; } } Hover small interactive experience Try passing the mouse over? .btn:hover:after{ animation: ripple 1s; } The effect is good, but if you move the mouse too quickly, the circle that just expanded will shrink back immediately, which is a bit inconsistent. But this is not the effect we want. What we hope is that it will be triggered once per click, rather than just putting it there and it will never be triggered again. active try In daily work, .btn:active:after{ animation: ripple 1s; } The effect is also unsatisfactory, a bit like holding down the mouse, you have to keep holding the mouse to trigger it completely. For example, in the example above, the animation runs for Focus Experience If you need to give focus to any element, you can assign a <a class="btn" tabindex="1">button</a> .btn:focus:after{ animation: ripple 1s; } Is there no solution? Of course there are some, the last one is definitely the solution, hahaha checked <label class="btn"> <input type="checkbox"><span>button</span> </label> We have changed Add some style .btn>span:after{ /**Change the selector**/ } .btn>input[type=checkbox]{ display: none } .btn>input[type=checkbox]:checked+span:after{ animation: ripple 1s; } This can also trigger the animation, but the problem is that when you click again, it becomes unselected. How to trigger the animation? In fact, it can be achieved with .btn>input[type=checkbox]:not(:checked)+span:after{ animation: ripple 1s; } At first glance, it seems quite clever, but if you think about it carefully, since animation is written on both the front and back sides, doesn’t it have anything to do with .btn>input[type=checkbox]+span:after{ animation: ripple 1s; } Infinite cycle... This problem has troubled me for a long time, but God will not let down those who work hard. Later, I tried to trigger different animations in two states and they can be triggered separately, as follows .btn>input[type=checkbox]:checked+span:after{ animation: ripple1 1s; } .btn>input[type=checkbox]:not(:checked)+span:after{ animation: ripple2 1s; } This should be easy to understand. Now, here comes the point. Now, if we change the animation process in This is very simple. We just need to set a default state, select a state, and then trigger animations with different names. .btn>input[type=checkbox]+span:after{ animation: ripple-in 1s; } .btn>input[type=checkbox]:checked+span:after{ animation: ripple-out 1s; } @keyframes ripple-in{ from { transform: translate(-50%,-50%) scale(0); background: rgba(0,0,0,.25); } to { transform: translate(-50%,-50%) scale(1); background: transparent; } } @keyframes ripple-out{/*only the name is different*/ from { transform: translate(-50%,-50%) scale(0); background: rgba(0,0,0,.25); } to { transform: translate(-50%,-50%) scale(1); background: transparent; } } The effect is as shown at the beginning of the article, perfect The complete demo is as follows https://codepen.io/xboxyan/pen/Jmvyex/ Some shortcomings Since the above animation style will be triggered by default, you will see the water drop animation on the button move once when the page loads, but it is not particularly obvious and acceptable. Secondly, the actual effect is definitely to spread from the point where the mouse is clicked. Our CSS certainly cannot do this, and can only spread from the center, which is also a compromise. Here is an idea. You can use The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. |
<<: Detailed explanation of the solution for real-time synchronization from MySQL to Oracle
>>: How to configure Nginx load balancing
A Thorough Analysis of HTML (14) Special Characte...
Our veteran predecessors have written countless c...
I heard that there is an interview question: How ...
Each time tomcat is started, the following log fi...
TeamCenter12 enters the account password and clic...
Xrdp is an open source implementation of Microsof...
Table of contents 1. parse 1.1 Rules for intercep...
NAT In this way, the virtual machine's networ...
Table of contents 1. Understanding Databases 1.1 ...
1. Import mysql command The mysql command import ...
This article introduces the implementation code o...
Table of contents 1. Class 1.1 constructor() 1.2 ...
Preface I recently wanted to learn CocosCreator, ...
I'm very happy. When encountering this proble...
1. Run fonts, open the font folder, and find the ...