首页前端开发JavaScriptJS实现情人节爱心满屏飘落的唯美特效(附完整代码)

JS实现情人节爱心满屏飘落的唯美特效(附完整代码)

时间2024-01-31 09:33:03发布访客分类JavaScript浏览676
导读:收集整理的这篇文章主要介绍了JS实现情人节爱心满屏飘落的唯美特效(附完整代码),觉得挺不错的,现在分享给大家,也给大家做个参考。214情人节将至,拥有浪漫细胞的程序员们估计已经迫不及待地让自己的网页装扮起来了~我也不例外,所以今天我就手把手...
收集整理的这篇文章主要介绍了JS实现情人节爱心满屏飘落的唯美特效(附完整代码),觉得挺不错的,现在分享给大家,也给大家做个参考。214情人节将至,拥有浪漫细胞的程序员们估计已经迫不及待地让自己的网页装扮起来了~我也不例外,所以今天我就手把手教大家如何制作一种浪漫背景的爱心满屏飞的动态效果。PS:非常欢迎技术大牛们留言讨论,帮我提出优化建议!

先看最终效果↓↓↓

前言:

文中效果是利用snowfall.jquery.js实现的,需要先引入jquery和snowfall.jquery.js。【推荐:javascript视频教程】

snowfall.jquery.js下载地址:https://www.npmjs.COM/package/jquery-snowfall

第一步:

利用伪元素before:after画两个重叠在一起的长方形,如图所示:

!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度,如图所示:

      .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 向左偏移一定像素,使两个微元素部分重叠,组成爱心样子,如图所示:

      .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就能实现,效果图如下:

完整代码如下:

!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>
    

其实个人觉得爱心画小一点比较好看,上面画那么大其实是为了方便大家看爱心更明显一些,把爱心画小后的效果图如下:

小的爱心,需改变以下属性的值:

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

粉色爱心场景图在下面,欢迎大家自取使用:

最后祝大家情人节快乐,发射爱心~biubiu~❥(^_-)~

以上就是JS实现情人节爱心满屏飘落的唯美特效(附完整代码)的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: js实现动态的“元宵节汤圆”特效...下一篇:聊聊Node.js + worker_threads如...猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: JS实现情人节爱心满屏飘落的唯美特效(附完整代码)
本文地址: https://pptw.com/jishu/593785.html
mod在vb中什么意思 c语言源程序的最小单位是什么

游客 回复需填写必要信息