jQuery + CSS:创造一个脉动的心脏

时间:2014-02-13 21:43:33

标签: javascript jquery html css css3

我使用纯CSS做了一个简单的心。 它由两部分组成,因此一件具有白色box-shadow,另一件具有红色:after

可以在这里找到一个例子:JsFiddle(它有一个简化的样式,没有渐变,所以看起来可能不漂亮:)。

所以,问题是:如何创建动画阴影?我所需要的只是让白色和红色的阴影产生脉动以产生心跳效果。

我已经遵循了一些类似的问题,但不幸的是,它们不会起作用,因为在我的情况下我使用:before和{{1}}伪类,这些不能通过jQuery操作

1 个答案:

答案 0 :(得分:5)

我把它设置为无限,所以它不停地跳动(这是一件好事,所以心脏不会死?)但你可以将它改为n数字而非时代。此外,您可以将5秒更改为更长或更短。如果你不希望盒子阴影变为0,你总是可以将它改为10px或者其他东西。

#b:before {
    animation: heartbeat 5s infinite;
}

@keyframes heartbeat {
    0% { box-shadow: 0 0 50px #fff; }
    25% { box-shadow: 0 0 0 #fff; }
    50% { box-shadow: 0 0 50px #fff; }
    75% { box-shadow: 0 0 0 #fff; }
    100% { box-shadow: 0 0 50px #fff; }
}

body {
    width:100%;
    margin:0;
    background: #000;
}
#b {
    position:relative;
    width:500px;
    height:90px;
    margin: 100px auto;
    font-size: 12px;
}
#b:before {
    position: absolute;
    content:"";
    left: 208px;
    top: 10px;
    width: 208px;
    height: 320px;
    background: red;
    border-radius: 200px 200px 0 0;
    box-shadow: 0 0 50px #fff;
    animation: heartbeat 5s infinite;
}
#b:before {
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transform-origin: 0 100%;
    -moz-transform-origin: 0 100%;
    -ms-transform-origin: 0 100%;
    -o-transform-origin: 0 100%;
    transform-origin: 0 100%;
}
#b:after {
    position:absolute;
    content:"BlaBla!";
    color: #fff;
    left:0;
    top:10px;
    width:208px;
    height:320px;
    background: red;
    border-radius:200px 200px 0 0;
    -webkit-transform:rotate(45deg);
    -moz-transform:rotate(45deg);
    -ms-transform:rotate(45deg);
    -o-transform:rotate(45deg);
    transform:rotate(45deg);
    -webkit-transform-origin:100% 100%;
    -moz-transform-origin:100% 100%;
    -ms-transform-origin:100% 100%;
    -o-transform-origin:100% 100%;
    transform-origin:100% 100%;
    box-shadow: 10px 10px 100px #6d0019;
}

@keyframes heartbeat {
    0% { box-shadow: 0 0 50px #fff; }
    25% { box-shadow: 0 0 0 #fff; }
    50% { box-shadow: 0 0 50px #fff; }
    75% { box-shadow: 0 0 0 #fff; }
    100% { box-shadow: 0 0 50px #fff; }
}
<div class="a">
    <div id="b"></div>
</div>