zoukankan      html  css  js  c++  java
  • vue 在移动端实现红包雨 (兼容性好)

    下面是代码:
    <template>
        <div class="ser_home">
            <ul class="red_packet" id="red_packet">
                <template v-for="(item, index) in liParams">
                    <li :style="{ left: item.left, animationDuration: item.durTime, webkitAnimationDuration: item.durTime}" 
      :class="item.cls" :data-index="index" @webkitAnimationEnd="removeDom">
                        <a href='javascript:;'>
                            <i :style="{ transform: item.transforms, webkitTransform: item.transforms}"></i>
                        </a>
                    </li>
                </template>
            </ul>
        </div>
    </template>


    <script>
    export default {
        data () {
            return {
                liParams: [],
                timer: null,
                duration: 10000 // 定义时间
            }
        },
        mounted () {
            this.startRedPacket()
        },
        methods: {
            /**
             * 开启动画
             */
            startRedPacket() {
                let win = document.documentElement.clientWidth || document.body.clientWidth
                let left = parseInt(Math.random() * (win - 50) + 0);
                
                let rotate = (parseInt(Math.random() * (45 - (-45)) - 45)) + "deg";  // 旋转角度
                let scales = (Math.random() * (12 - 8 + 1) + 8) * 0.1;  // 图片尺寸
                let durTime = (Math.random() * (2.5 - 1.2 + 1) + 1.2) + 's'; // 时间  1.2和1.2这个数值保持一样
                console.log(durTime)
                this.liParams.push({left: left+'px', cls: 'move_1', transforms: 'rotate('+ rotate +') scale('+ scales +')', durTime: durTime})


                setTimeout( () =>  {   // 多少时间结束
                    clearTimeout(this.timer)
                    return;
                }, this.duration)


                this.timer = setTimeout( () => {
                    this.startRedPacket()
                },100)   
            },
            /**
             * 回收dom节点
             */
            removeDom (e) {
                let target = e.currentTarget;
                document.querySelector('#red_packet').removeChild(target)
            }
        }
    }
    </script>


    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped lang="scss">
    .ser_home {
        100%;
        height: 100%;
    }
    .red_packet {
        display: block;
        position: relative;
        overflow: hidden;
        100%;
        height: 100%;
        i {
            48px;
            height: 69px;
            display: block;
            background: url('/hongbao.png') no-repeat;
        }
        li {
            position: absolute;
            animation: all 3s linear;
            top:-100px;
            z-index: 10;
            &.move_1 {
                -webkit-animation: aim_move 5s linear 1 forwards;
                animation: aim_move 5s linear 1 forwards;
            }
        }
        a {
            display: block;
        }
    }


    @keyframes aim_move {
          0% {
            -webkit-transform: translateY(0);
            transform: translateY(0);
          }
          100% {
            -webkit-transform: translateY(120vh);
            transform: translateY(120vh);
          }
        }


    </style>
    ---------------------
    作者:彻夜不归
    来源:CSDN
    原文:https://blog.csdn.net/qq_40204835/article/details/79173685
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    hibernate执行createSQLQuery时字段重名的问题
    注意JDBC驱动的版本和JDK的版本是否匹配 JDBC连接Mariadb
    MariaDBConn用于链接MariaDB的管理类
    PLSQL Developer对oracle中的数据进行备份恢复
    JQuery判断浏览器类型
    IE与非IE window.onload调用
    如何升级centos到最新版本
    bootstrap 后台模板
    FontAwesome 4.7.0 中完整的675个图标样式CSS参考
    Linux Crontab及使用salt进行管理
  • 原文地址:https://www.cnblogs.com/zhoudawei/p/10967503.html
Copyright © 2011-2022 走看看