jQuery实现炸裂轮播

jQuery实现炸裂轮播图

最终效果:
图片炸裂成碎片,同时更换图片
css代码:

<style>
    *{
        margin: 0;
        padding: 0;
    }
    .box{
        width: 600px;
        height: 400px;
        border:1px solid #000000;
        background-color: darkslategrey;
        position: relative;
        margin:100px auto;
        display: flex;
        flex-wrap: wrap;
        overflow: hidden;
    }
    .child{
        width: 60px;
        height: 40px;
        box-sizing: border-box;
        text-align: center;
        position: relative;
        line-height: 40px;
        background-image: url(./images/01.jpg);
        background-size: 600px 400px;
        transition: 0.5s;
        
    }
</style>

HTML+JS代码:

<body>
    <div class="box"></div>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.js"></script>
    <script>
        var str=''
        var timerId=null
        var a=1;
        for(var i=0;i<=99;i++){
        str+='<div class="child">'+i+'</div>'    
        $('.box').html(str)                       //循环添加子节点
        }
        init()                                        //调用初始化函数
        function init(){                         //初始化函数,确定初始样式
            for(var i=0;i<100;i++){
                var x=-($('.child').eq(i).offset().left-$('.box').offset().left-1)+'px'
                var y=-($('.child').eq(i).offset().top-$('.box').offset().top-1)+'px'   //找到每一个子元素的位置
               console.log(x,y)
          $('.child').eq(i).css('background-position',x+' '+y)   //将背景图片的相对位置设置到子元素(每一个child取图片的不同位置,以此拼成大的图片)
        }
        }

         function boom(){             //炸裂函数
             for(var i=0;i<100;i++){
                var num  =parseInt(Math.random()*100)        
                var numx1=parseInt(Math.random()*100)
                var numy1=parseInt(Math.random()*100)
                var numx=parseInt(Math.random()*180)           //获取随机数
                var numx=numx1-num                                     //实现正负随机数
                var numy=numy1-num 
                $('.child').eq(i).css('marginLeft',numx+'px')         //随机改变图片的位置
                $('.child').eq(i).css('marginTop',numy+'px')
                $('.child').eq(i).css('transform','rotateX('+numx+'deg)')
                $('.child').eq(i).css('opacity','0.5')
             }
         }

        function guiwei(a){          //还原函数
                $('.child').css('marginLeft','')           //将原来的属性清空,就会还原初始状态
                $('.child').css('marginTop','')
                $('.child').css('opacity','1')
                $('.child').css('transform','')
                $('.child').css('background-image','url(./images/0'+a+'.jpg)')  //同时改变图片路径
        }

         timerId=setInterval(function(){       //定时器
            boom()
            setTimeout(function(){
                a++
                if(a>4){
                    a=1
                }
                guiwei(a)
               
            },1000)
         },2000)
    </script>
</body>

效果图:
炸裂轮播效果图

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大兵的猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值