js-10*10个div-制作整图碎片化效果

本文介绍了一种利用JavaScript和CSS实现整图碎片化并逐渐消失的视觉效果的方法。通过随机化图片的位置、倾斜角度及调整透明度,可以达到图片破碎且逐渐淡出的动画效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      在学会使用js将一个div变成10*10个div组成后,具体参照js-使用js生成10*10个带标号的div。研究了下如何做出整图碎片化的效果。其实实现原理很简单,使用Math.random()使每个图片位移值和斜切值为任意值,同时设置图片的透明度,就可以制作出整图碎片化并消失不见的效果。
      html代码中只需写一个div作为外框,故不赘述。css代码如下所示:

#wrap{
    margin:30px auto;
    width: 600px;
    height: 500px;
    position:relative;
    perspective: 800px;
    transform-style: preserve-3d;
}
#wrap div{
    width: 60px;
    height: 50px;
    position:absolute;
    opacity: 1;
    background-image: url(../img/bg.jpg);
    background-repeat: no-repeat;
    transition: 1s;
    transform-origin: 0 0;
}
#wrap .active{
    opacity: 0;
    transform: rotate(360deg) scale(0); 
}

      js代码如下:

var box = document.querySelector('#wrap');
var divW = 60;
var divH = 50;
var inner = "";
for(var i = 0; i < 100; i++) {
    var x = i % 10;
    var y = parseInt(i/10);
    inner+="<div style='background-position:-"
    +(x*divW)+"px -"+(divH*y)+"px;left:"
    + (x*divW) + "px;top:" + (divH*y)+"px'></div>";
}
box.innerHTML = inner;
var divs=box.getElementsByTagName("div");
for(var i=0;i<divs.length;i++){
//鼠标移动到图片的某个位置,该位置的小图片旋转360°并透明度为0
        divs[i].onmouseover=function(){
        this.className="active";
    }
}
var picBgArr=["bg.jpg","bg2.jpg","bg3.jpg"];
var num=0;
var onoff=true;//设置开关,作为判断是否已碎片化的条件
document.onclick=function(){
    if(onoff){
    //化整为0
        for(var i=0;i<divs.length;i++){
            divs[i].style.transform="skew("+      (60*Math.random())+"deg)  translateZ("+(Math.random()*1000)+"px)";
            divs[i].style.opacity="0";
        }
        onoff=false;
    }else{
        num+=1;
        if(num==picBgArr.length){
            num=0;
        }
    //化0为整,并显示为下一张图
        for(var i=0;i<divs.length;i++){
            divs[i].className="";
            divs[i].style.transform=""; 
            divs[i].style.opacity="";
            divs[i].style.backgroundImage="url(img/"+picBgArr[num]+")";
        }
        onoff=true;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值