时间:2021-05-25
前言
所谓文字聚合效果,原理就是将容器分为若干的小块,然后每个小块设置 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; };完整的示例如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:///wpimg/2_1.png) no-repeat;background-size: 160px auto; position: absolute; left: 0px;top: 0px; } .boxWrap1.set div{ opacity: 1!important; transform:perspective(800px) translate3d(0px,0px,0px) rotate(0deg) scale(1)!important; -moz-transform:perspective(800px) translate3d(0px,0px,0px) rotate(0deg) scale(1)!important; -webkit-transform:perspective(800px) translate3d(0px,0px,0px) rotate(0deg) scale(1)!important; } .boxSiteWrap{ width: 100%;overflow: hidden;height: auto; background: #000;padding: 140px 0} .boxSiteWrap button{cursor:pointer;display: block;font-size: 16px; width: 140px;height: 40px; background: #fff;color: #000;border:none;margin:30px auto;}</style></head><body><div class="boxSiteWrap"><div class="boxWrap1"></div><button>重新加载</button></div><script>window.addEventListener('load',function(){;(function(){ function init(){ 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; _div.style.cssText = 'width:'+w+'px;height:'+h+'px;left:'+_left+'px;top:'+_top+'px; opacity:0;background-position:'+(-_left) + 'px ' + (-_top) + 'px'; _div.style.transition = _div.style.MozTransition = _div.style.WebkitTransition = 'all '+ Random(1,1.8) +'s ease'; _div.style.transform = _div.style.MozTransform = _div.style.WebkitTransform = '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; }; }; init(); var flag = true; document.querySelector('button').onclick = function(){ if(flag){ document.querySelector('.boxWrap1').classList.remove('set') setTimeout(function(){ document.querySelector('.boxWrap1').innerHTML = ''; init(); flag = true; },1200); flag = false; }; };})();});</script></body></html>总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
利用ppt制作文字动画效果,主要使用的飞出飞入动画效果,对该动画进行相应参数设置实现的,现在就把操作的过程和截图分享出来,供大家参考使用。软件名称:PowerP
本文实例讲述了JS实现超炫网页烟花动画效果的方法。分享给大家供大家参考。具体分析如下:非常炫的使用JS实现的一个网页烟花燃放动画效果,能适应JS做出这样的动画来
本文实例为大家分享了Android自定义加载圈动画展示的具体代码,供大家参考,具体内容如下实现如下效果:该效果图主要有3个动画:1.旋转动画2.聚合动画3.扩散
前面学习了用css实现动画效果,那Vue中能不能用js实现动画效果呢?其实Vue提供了很多动画钩子enter入场动画钩子函数有before-enter、ente
iOS基本动画/关键帧动画/利用缓动函数实现物理动画效果先说下基本动画部分基本动画部分比较简单,但能实现的动画效果也很局限使用方法大致为:#1.创建原始UI或者