纯JS实现按钮抖动效果

纯JS代码实现按钮左右抖动效果代码,基本不会存在与jquery脚本可能冲突的情况。

效果如下:

JS实现按钮抖动效果

HTML代码:

<button class="btn" id="btn">Just a button</button>

CSS代码:

body {
    min-height: 100vh;
    font-family: Roboto,Arial;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #1499f7;
}

.btn {
    -webkit-appearance: none;
    border: 0;
    position: relative;
    height: 63px;
    width: 240px;
    padding: 0;
    cursor: pointer;
    border-radius: 32px;
    overflow: hidden;
    -webkit-mask-image: -webkit-radial-gradient(white,black);
}

JS代码:

document.getElementById('btn').addEventListener('click', function(e) {
    Shaking(e.target)
})

function Shaking(el) {
    const maxDistance = 5 // 抖动偏移距离
    const interval = 12 // 抖动快慢,数字越小越快,太小DOM反应不过来,看不出动画
    const quarterCycle = 8 // 一次完整来回抖动的四分之一周期
    let curDistance = 0
    let direction = 1
    const timer = setInterval(function() {
        if (direction > 0) {
            curDistance++
            if (curDistance === maxDistance) {
                direction = -1
            }
        } else {
            curDistance--
            if (curDistance === -maxDistance) {
                direction = 1
            }
        }
        el.style.left = curDistance + 'px';
    }, interval)
    setTimeout(function() {
        clearInterval(timer)
        el.style.left = '0 px';
    }, maxDistance * interval * quarterCycle);
}

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:
1. 本站所有文章教程及资源素材均来源于网络与用户分享或为本站原创,仅限用于学习和研究。
2. 如果内容损害你的权益请联系客服QQ:1642748312给予处理。
码云笔记 » 纯JS实现按钮抖动效果

发表评论

IT互联网行业相关广告投放 更专业 更精准

立即查看 联系我们