我正在为我的网站使用CSS和动画,并且非常喜欢Drawception网站使用的加载CSS的外观。他们的代码只进行90度动画然后重置。我想让我做一个完整的360度旋转,因为我的内部也会有一个旋转的图像。 这是我正在使用的代码:
<style>
.loading-box2{
width: 35px;
height: 35px;
margin: 0px auto;
}
.loading-box2:before{
content: '';
width: 35px;
height: 5px;
background: #000;
opacity: 0.1;
position: absolute;
top: 44px;
right: 42%;
margin-left: -15px;
border-radius: 50%;
animation: shadow360 2s linear infinite;
}
.loading-box2:after{
content: ':o)';
line-height: 35px;
text-align: center;
font-size: 12px;
width: 35px;
height: 35px;
background: #fffdc9;
animation: boxbounce360 2s linear infinite;
position: absolute;
top: 0;
right: 42%;
margin-left: -15px;
border-radius: 3px;
border: 1px solid #c0c0c0;
/* colours here added while testing */
border-right: 1px solid #f00;
border-top: 1px solid #0f0;
border-left: 1px solid #ff0;
border-bottom: 1px solid #f0f;
}
@keyframes boxbounce360{
3.25%,24.25%,28.25%,49.25%,55.25%,74.25%,78.25%,99.25%{border-radius: 3px; border-bottom-right-radius: 3px;}
0%{transform:translateY(0) rotate(0deg)}
7.84375%{transform: translateY(9px) rotate(22.5deg)}
13.5625%{transform: translateY(18px) scale(1, .9) rotate(45deg);border-bottom-right-radius: 40px}
19.25125%{transform: translateY(9px) rotate(67.5deg)}
25%{transform: translateY(0) rotate(90deg)}
32.84375%{transform: translateY(9px) rotate(112.5deg)}
38.5625%{transform: translateY(18px) scale(1, .9) rotate(135deg);border-top-right-radius: 40px}
44.28125%{transform: translateY(9px) rotate(157.5deg)}
50%{transform: translateY(0) rotate(180deg)}
59.84375%{transform: translateY(9px) rotate(202.5deg)}
64.5625%{transform: translateY(18px) scale(1, .9) rotate(225deg);border-top-left-radius: 40px}
69.28125%{transform: translateY(9px) rotate(247.5deg)}
75%{transform: translateY(0) rotate(270deg)}
82.84375%{transform: translateY(9px) rotate(292.5deg)}
88.5625%{transform: translateY(18px) scale(1, .9) rotate(315deg);border-bottom-left-radius: 40px}
94.28125%{transform: translateY(9px) rotate(337.5deg)}
100%{transform: translateY(0) rotate(360deg)}
}
@keyframes shadow360{
0%,25%,50%,75%,100%{transform: scale(1, 1)}
13.5625%,38.5625%,64.5625%,88.5625%{transform: scale(1.2, 1)}
}
</style>
<body>
<div class="loading-box2">
</body>
和jsfiddle一样here。
在Chrome中,动画运行完美,始终朝同一方向旋转。但在Internet Explorer 11中,它会达到180度然后旋转回0! 任何想法我如何为IE修复它,最好不需要任何Javascript,但我不介意它是否确实需要它。
答案 0 :(得分:0)
我设法破解了修复程序......我添加了一个额外的关键帧:
50%{transform: translateY(0) rotate(180deg)}
50.1%{transform: rotate(180.5deg)} <---- this one
59.84375%{transform: translateY(9px) rotate(202.5deg)}
现在它看起来不再像是在IE浏览器的中途旋转,即使它仍然在做!