Ian*_*Ian 6 html css animation css3 css-animations
我正在尝试在纯CSS中重新创建材质设计涟漪效果,并且我已准备好动画.问题是,单击元素时,我无法使动画一直运行.我尝试过转换(尝试1个演示,尝试2个演示),但这些都不会一直运行.
另一个更可能的方法是使用CSS3动画(我现在不担心浏览器支持).我已准备好动画关键帧,但我之前从未使用动画,我没有看到在点击时运行动画的方法.
@-webkit-keyframes ripple {
0% {
background-size: 1% 1%;
opacity: 0.5;
}
70% {
background-size: 1000% 1000%;
opacity: 0.2;
}
100% {
opacity: 0;
background-size: 1000% 1000%;
}
}
@keyframes ripple {
0% {
background-size: 1% 1%;
opacity: 0.5;
}
70% {
background-size: 1000% 1000%;
opacity: 0.2;
}
100% {
opacity: 0;
background-size: 1000% 1000%;
}
}
.button {
background-color: blue;
padding: 12px;
display: inline-block;
border-radius: 5px;
color: white;
font-family: sans-serif;
text-transform: uppercase;
position: relative;
overflow: hidden;
}
.button::after {
position: absolute;
content: " ";
height: 100%;
width: 100%;
top: 0;
left: 0;
pointer-events: none;
background-image: radial-gradient(circle at center, #FFF 0%, #FFF 10%, transparent 10.1%, transparent 100%);
background-position: center center;
background-repeat: no-repeat;
background-color: transparent;
-webkit-animation: ripple 0.6s 0s normal forwards infinite running ease-in;
animation: ripple 0.6s 0s normal forwards infinite running ease-in;
}
.button:active::after {
/*Somehow the animation needs to run on click only, and then run all the way through*/
}
Run Code Online (Sandbox Code Playgroud)
<div class="ripple button"><a>Click this</a></div>
Run Code Online (Sandbox Code Playgroud)
我曾经想过但却无法完成工作的事情包括改变动画延迟,使::after
透明使用opacity
以及使用动画计时功能.
小智 1
尝试一下,但你需要使用 jquery 来保持按钮处于活动状态,我没有使用 jquery 因此按住单击;
@-webkit-keyframes ripple {
0% {
background-size: 1% 1%;
opacity: 0.5;
}
70% {
background-size: 1000% 1000%;
opacity: 0.2;
}
100% {
opacity: 0;
background-size: 1000% 1000%;
}
}
@keyframes ripple {
0% {
background-size: 1% 1%;
opacity: 0.5;
}
70% {
background-size: 1000% 1000%;
opacity: 0.2;
}
100% {
opacity: 0;
background-size: 1000% 1000%;
}
}
.button {
background-color: blue;
padding: 12px;
display: inline-block;
border-radius: 5px;
color: white;
font-family: sans-serif;
text-transform: uppercase;
position: relative;
overflow: hidden;
}
.button:active:after{
position: absolute;
content: " ";
height: 100%;
width: 100%;
top: 0;
left: 0;
pointer-events: none;
background-image: radial-gradient(circle at center, #FFF 0%, #FFF 10%, transparent 10.1%, transparent 100%);
background-position: center center;
background-repeat: no-repeat;
background-color: transparent;
-webkit-animation: ripple 0.6s 0s normal forwards infinite running ease-in;
animation: ripple 0.6s 0s normal forwards infinite running ease-in;}
Run Code Online (Sandbox Code Playgroud)
<div class='ripple button'><a href=''>hell</a></div>
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2738 次 |
最近记录: |