利用JS实现文字的聚合动画效果
前言
专注于为中小企业提供网站设计制作、做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业巫溪免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了成百上千企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
所谓文字聚合效果,原理就是将容器分为若干的小块,然后每个小块设置 background-poisition
,最后添加css3动画就可以了,去掉注释,也就仅仅20行的代码。
先来看看效果图:
js代码如下:
//c为列数,r为行数,把box划分成多少个小块 var box = document.querySelector('.boxWrap1'),c=4,r=8; //每个小块的宽高 var w = box.offsetWidth/c,h = box.offsetHeight/r; //循环添加小块 for(var i = 0;i < r;i++){ for(var j = 0;j < c;j++) { var _div=document.createElement('div'); var _left = j * w,_top = i * h; //添加css样式,并设置每个小块的背景 _div.style.cssText = 'width:'+w+'px;height:'+h+'px;left:'+_left+'px;top:'+_top+'px; opacity:0;background-position:'+(-_left) + 'px ' + (-_top) + 'px'; //添加css动画时间 _div.style.transition = 'all '+ Random(1,1.8) +'s ease'; //添加css的transform动画 _div.style.transform = 'perspective(800px) translate3d('+Random(-200,200)+'px, '+Random(-200,200)+'px,300px) rotate('+Random(-90,90)+'deg) scale('+ Random(0,2) +')' //添加 box.appendChild(_div); }; }; //延时添加动画 setTimeout(function(){ box.classList.add('set'); },100); //随机数 function Random(start,end){ return Math.random()*(end-start)+start; };
完整的示例如下:
利用JS实现文字的聚合动画效果
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
文章标题:利用JS实现文字的聚合动画效果
本文路径:http://pwwzsj.com/article/jogchp.html