国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

利用JS實現文字的聚合動畫效果

2019-11-19 17:48:49
字體:
來源:轉載
供稿:網友

前言

所謂文字聚合效果,原理就是將容器分為若干的小塊,然后每個小塊設置 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://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>利用JS實現文字的聚合動畫效果</title><style>	.boxWrap1{width: 160px;height: 417px;position: relative;margin:0px auto;}	.boxWrap1 img{width: 100%;}	.boxWrap1 div{background: url(http://itakeo.com/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>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昭觉县| 昔阳县| 堆龙德庆县| 申扎县| 桐乡市| 屏东县| 珠海市| 繁昌县| 雷山县| 鄂温| 手游| 土默特右旗| 隆德县| 玛纳斯县| 临漳县| 乌海市| 石门县| 永安市| 子洲县| 南雄市| 吉木萨尔县| 兴仁县| 文山县| 陇川县| 纳雍县| 新疆| 昌乐县| 西贡区| 图木舒克市| 临猗县| 新巴尔虎左旗| 新竹市| 贺兰县| 普兰县| 长阳| 凯里市| 通城县| 南皮县| 武隆县| 固原市| 兴业县|