溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

CSS+JS怎么實現(xiàn)愛心點贊按鈕

發(fā)布時間:2021-11-20 09:11:25 來源:億速云 閱讀:186 作者:iii 欄目:web開發(fā)

本篇內(nèi)容主要講解“CSS+JS怎么實現(xiàn)愛心點贊按鈕”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“CSS+JS怎么實現(xiàn)愛心點贊按鈕”吧!

CSS+JS怎么實現(xiàn)愛心點贊按鈕

ToDoList

  • 愛心按鈕

  • 引導點贊

  • 愛之滿滿

Just Do It

?? 愛心按鈕

  • 制作一個愛心的方式有很多,可以用圖標庫的愛心,可以寫一個svg,可以用圖片,我這里就用偽元素的方式做一個愛心。(學習視頻分享:css視頻教程)

<!-- fullLove.html -->
<div class="likeBtn" id="likeBtn">
    <span class="heart" id="heart"></span>
</div>
/* fullLove.css */
.heart{
    background-color: #8a93a0;
    height: 13px;
    width: 13px;
    transform: rotate(-45deg) scale(1);
    display: inline-block;
}
.heart::before {
    content: '';
    position: absolute;
    top: -50%;
    left: 0;
    background-color: inherit;
    border-radius: 50%;
    height: 13px;
    width: 13px;
}
.heart::after {
    content: '';
    position: absolute;
    top: 0;
    right: -50%;
    background-color: inherit;
    border-radius: 50%;
    height: 13px;
    width: 13px;
}
  • 再給外層加一些陰影就可以出來擬態(tài)化效果

CSS+JS怎么實現(xiàn)愛心點贊按鈕

引導點贊

  • 我們需要讓按鈕做出一些視覺效果來引導觀眾姥爺們點贊,那持續(xù)震動無疑是一種好的選擇。

// love.js
const likeBtn = document.getElementById('likeBtn');
const heart=document.getElementById('heart')
likeBtn.addEventListener('mousemove',() => {
  heart.classList.add('heratPop')
})
likeBtn.addEventListener('mouseout',() => {
  heart.classList.remove('heratPop')
})
/* fullLove.css */
.heratPop{
    animation: pulse 1s linear infinite;
}
@keyframes pulse {
    0% {
            transform: rotate(-45deg) scale(1);
    }
    10% {
            transform: rotate(-45deg) scale(1.1);
    }
    20% {
            transform: rotate(-45deg) scale(0.9);
    }
    30% {
            transform: rotate(-45deg) scale(1.2);
    }
    40% {
            transform: rotate(-45deg) scale(0.9);
    }
    50% {
            transform: rotate(-45deg) scale(1.1);
    }
    60% {
            transform: rotate(-45deg) scale(0.9);
    }
    70% {
            transform: rotate(-45deg) scale(1);
    }
}

愛之滿滿

  • 接下來就是最主要的愛之滿滿了,怎么樣才能達到這種效果呢,那必然是越多的愛越好啊。

  • 那我們想辦法讓愛心漂浮在按鈕周圍,在規(guī)定時間內(nèi)愛心進行位移并消失即可。

  • 創(chuàng)建一個元素可以使用document.createElement,移除元素可以使用DOMremove()

  • 剩下的就簡單了,只需要在這個過程中不同的愛心設置不同的大小和位移即可。

  • 核心代碼(完整代碼請看文末):

// love.js
function addHearts(content) {
  for(let i=0; i<10; i++) {
    setTimeout(() => {
      const fullHeart = document.createElement('div');
      fullHeart.classList.add('hearts');
      fullHeart.innerHTML = '<span class="heart"></span>';
      fullHeart.style.left = Math.random() * 100 + '%';
      fullHeart.style.top = Math.random() * 100 + '%';
      fullHeart.style.transform = `translate(-50%, -50%) scale(${Math.random()+0.3}) `
      fullHeart.style.animationDuration = Math.random() * 2 + 3 + 's';
      fullHeart.firstChild.style.backgroundColor='#ed3056'
      content.appendChild(fullHeart);
      setTimeout(() => {
        fullHeart.remove();
      }, 3000);
    }, i * 100)
  }
}
/* fullLove.css */
.hearts {
    position: absolute;
    color: #E7273F;
    font-size: 15px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: fly 3s linear forwards;
}
@keyframes fly {
    to {
        transform: translate(-50%, -50px) scale(0);
    }
}

到此,相信大家對“CSS+JS怎么實現(xiàn)愛心點贊按鈕”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI