JS實現情人節愛心滿屏飄落的唯美特效(附完整程式碼)

2022-02-12 16:00:23
214情人節將至,擁有浪漫細胞的程式設計師們估計已經迫不及待地讓自己的網頁裝扮起來了~我也不例外,所以今天我就手把手教大家如何製作一種浪漫背景的愛心滿屏飛的動態效果。PS:非常歡迎技術大牛們留言討論,幫我提出優化建議!

先看最終效果↓↓↓

GIF 2022-2-12 星期六 上午 9-39-55.gif

前言:

文中效果是利用snowfall.jquery.js實現的,需要先引入jquery和snowfall.jquery.js。【推薦:】

snowfall.jquery.js下載地址:https://www.npmjs.com/package/jquery-snowfall

第一步:

利用偽元素before:after畫兩個重疊在一起的長方形,如圖所示:

6863d33314d4e8f0471f87b6782f49d.png

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title></title>
    <style media="screen">
        body {
            overflow-y: hidden;
        }
        .heart-body {
            width: 500px;
            margin: 100px auto;
            position: relative;
        }
        .snowfall-flakes:before,
        .snowfall-flakes:after {
            content: "";
            position: absolute;
            left: 0px;
            top: 0px;
            display: block;
            width: 30px;
            height: 46px;
            background: red;
            border-radius: 50px 50px 0 0;
        }
    </style>
</head>
<body>
    <div class="heart-body">
        <div class="snowfall-flakes"></div>
    </div>
</body>
</html>

第二步:

利用 transform 屬性將兩個兩個偽元素分別旋轉負45度、45度,如圖所示:

4487bdb09c5d1c36b8c60c98e1b03dc.png

      .snowfall-flakes:before {
            -webkit-transform: rotate(-45deg);
            /* Safari 和 Chrome */
            -moz-transform: rotate(-45deg);
            /* Firefox */
            -ms-transform: rotate(-45deg);
            /* IE 9 */
            -o-transform: rotate(-45deg);
            /* Opera */
            transform: rotate(-45deg);
        }
        .snowfall-flakes:after {
            -webkit-transform: rotate(45deg);
            /* Safari 和 Chrome */
            -moz-transform: rotate(45deg);
            /* Firefox */
            -ms-transform: rotate(45deg);
            /* IE 9 */
            -o-transform: rotate(45deg);
            /* Opera */
            transform: rotate(45deg);
        }

第三步:

利用 left 屬性,將偽元素 after 向左偏移一定畫素,使兩個微元素部分重疊,組成愛心樣子,如圖所示:

66cee6b5ac3e97b9d1a8ab0d68cfa53.png

      .snowfall-flakes:after {
            left: 13px;
            -webkit-transform: rotate(45deg);
            /* Safari 和 Chrome */
            -moz-transform: rotate(45deg);
            /* Firefox */
            -ms-transform: rotate(45deg);
            /* IE 9 */
            -o-transform: rotate(45deg);
            /* Opera */
            transform: rotate(45deg);
        }

愛心我們畫完了,那麼怎麼讓愛心實現滿屏飛呢,其實只需要呼叫jquery.js和 snowfall.jquery.js就能實現,效果圖如下:

GIF 2022-2-12 星期六 上午 9-44-42.gif

完整程式碼如下:

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title></title>
    <style media="screen">
        body {
            overflow: hidden;
        }

        .heart-body {
            width: 500px;
            margin: 100px auto;
            position: relative;
        }

        .snowfall-flakes:before,
        .snowfall-flakes:after {
            content: "";
            position: absolute;
            left: 0px;
            top: 0px;
            display: block;
            width: 30px;
            height: 46px;
            background: red;
            border-radius: 50px 50px 0 0;
        }

        .snowfall-flakes:before {
            -webkit-transform: rotate(-45deg);
            /* Safari 和 Chrome */
            -moz-transform: rotate(-45deg);
            /* Firefox */
            -ms-transform: rotate(-45deg);
            /* IE 9 */
            -o-transform: rotate(-45deg);
            /* Opera */
            transform: rotate(-45deg);
        }

        .snowfall-flakes:after {
            left: 13px;
            -webkit-transform: rotate(45deg);
            /* Safari 和 Chrome */
            -moz-transform: rotate(45deg);
            /* Firefox */
            -ms-transform: rotate(45deg);
            /* IE 9 */
            -o-transform: rotate(45deg);
            /* Opera */
            transform: rotate(45deg);
        }
            .bgimg{
            position:fixed;
            top: 0;
            left: 0;
            width:100%;
            height:100%;
            min-width: 1000px;
            z-index:-10;
            zoom: 1;
            background-color: #fff;
            background: url(bgimg.jpg) no-repeat;
            background-size: cover;
            -webkit-background-size: cover;
            -o-background-size: cover;
            background-position: center 0;
    }
    </style>
</head>

<body>
  <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" type="text/javascript"></script>
  <script src="snowfall.jquery.js"></script>
  <script>
      //呼叫飄落函數 實現飄落效果
      $(document).snowfall({
          flakeCount: 50 //愛心的個數
      });
      $(window).resize(function () {
        //當瀏覽器大小變化時
        location.reload(true);
      });
  </script>
  <div class="bgimg"></div>
</body>

</html>

其實個人覺得愛心畫小一點比較好看,上面畫那麼大其實是為了方便大家看愛心更明顯一些,把愛心畫小後的效果圖如下:

GIF 2022-2-12 星期六 上午 9-39-55.gif

小的愛心,需改變以下屬性的值:

        .snowfall-flakes:before,
        .snowfall-flakes:after {
            width: 10px;
            height: 16px;
            border-radius: 10px 10px 0 0;
        }
        .snowfall-flakes:after {
            left: 4px;
        }

粉色愛心場景圖在下面,歡迎大家自取使用:

最後祝大家情人節快樂,發射愛心~biubiu~❥(^_-)~

以上就是JS實現情人節愛心滿屏飄落的唯美特效(附完整程式碼)的詳細內容,更多請關注TW511.COM其它相關文章!