首页 期权学习期权知识正文

jquery轮播图加easing特效 easing运动效果插件使用方法详解

xiaojiucai 期权知识 2020-08-18 505 0

是一款比较老的jQuery插件,在很多网站都有应用,尤其是在一些页面滚动、幻灯片切换等场景应用比较多。它非常小巧,且有多种动画方案供选择,使用简单,而且免费的。

jQuery Easing是在jQuery原有的动画效果上进行了扩展,所以使用时可以根据jQuery原有的动画函数进行扩展。

支持toggle()、slideUp()、slideDown()、show()、hide()等jQuery内置的动画效果。下面演示开始了:

<!DOCTYPE html>    
<html>    
	<head>    
		<meta charset="UTF-8">    
		<title></title>    
		<style type="text/css">    
			*{    
				padding: 0;    
				margin: 0;    
			}    
			#tm{    
				width: 750px;    
				height: 291px;    
				border: 2px solid darkblue;    
				margin: 100px auto;    
				position: relative;    
				overflow: hidden;    
			}    
			#tm .dk{    
				/*width: 3750px;*/    
				width: 4500px;    
				height: 291px;    
				border: 2px solid darkgreen;    
				position: absolute;    
				left: 0;    
				top: 0;    
			}    
			#tm .dk img{    
				float: left;    
			}    
			#tm ul{    
				position: absolute;    
				bottom: 0;    
				right: 0;    
			}    
			#tm ul li{    
				list-style: none;    
				float: left;    
				width: 116px;    
				height: 29px;    
				line-height: 29px;    
				text-align: center;    
				color: white;    
				font-size: 12px;    
				font-family: "宋体";    
				background: black;    
				opacity: 0.6;    
				margin-left: 1px;    
			}    
			#tm ul li:hover{    
				/*没下划线*/    
				/*text-decoration: none;*/    
				/*有下划线*/    
				text-decoration: underline;    
				color: #c00;    
			}    
		</style>    
		<script src="../tu/jquery-1.11.3.min.js" type="text/javascript"></script>    
		<script src="../tu/jquery.easing.1.3.js" type="text/javascript"></script>    
		<script type="text/javascript">    
			$(function(){    
//				先弄一个大总管变量    
				var t = 0;    
//				让定时器在自动跑的时候,点击是无效的  用一个变量去判断    
				var k = 2; //用来对应能否点击的状态   1代表不能点击,2代表能点击 (这个可以不写,我看了写这个东西后bug更多)    
//				自动轮播   控制自动轮播的函数    
				function hs(){    
				t++;    
////				###########(*****)下面的(我删了,想看到02页面里看)可以这样写  最后的小bug,当li opacity变色的时候图片跑到第6个(最后的时候)  li的颜色也回到第0个    
				if (t==5) {    
					$('#tm ul li').eq(0).css({'opacity':'0.8'}).siblings('li').css({'opacity':'0.6'});    
				}    
				if (t==6) {    
					$('#tm .dk').css({'left':'0px'});    
					t=1;    
				}    
//				计算大div应该到达的left值    
//				var y = -750*t;    
				var y = t*-750;    
				k=1; //  在函数过程中,在运动之前先变成1  在函数运动过程中   1代表不能点击    
				$('#tm .dk').animate({'left':y+'px'},800,'easeOutElastic',function(){    
					k=2;//运动300毫秒完事后  再变成能点击2	
    
				});    
//				让t号li透明度变0.8,兄弟li透明度变0.6    
				$('#tm ul li').eq(t).css({'opacity':'0.8'}).siblings('li').css({'opacity':'0.6'});    
				}    
				var dsq = setInterval(hs,2000);    
				var w;  //在单击事件前 ,先声明一个变量,用来清除定时器     因为每次点击都会出来一个定时炸弹,快速点击很多次会出现定时炸弹叠加				
    
//				给li加鼠标单击事件    
				$('#tm ul li').click(function(){    
					if (k==1) {//当k等于1时,不能点击    
						return;    
					}    
					clearInterval(w);    
//					(解决定时器和点击效果冲突)  1、当我点击的时候(没有定时器)清理定时器    
					clearInterval(dsq);					
    
//					解决定时器和点击效果冲突  方法(二)   设一下定时炸弹来控制  (本来是300毫秒的,设置成400毫秒,为防止毫秒数有误差)400毫秒后恢复定时器    
					w=setTimeout(function(){    
					dsq = setInterval(hs,2000);	
    
					},900)    
//					获得当前被点击li的序号    
					t=$(this).index();    
//					计算大div应该到达的lfet值    
					var left = t*-750;    
					$('#tm .dk').stop().animate({'left':left+'px'},800,'easeOutElastic');										
    
//					stop()消除叠加运动    
//					$('#tm .dk').stop().animate({'left':left+'px'},300,functon(){    
////						解决定时器和点击效果冲突  方法(一) 2、用回调函数来恢复定时器  可以在执行完前面运动的300毫秒后,再执行回调函数里的内容    
//						dsq = setInterval(hs,1000);    
//					});    
//					让当前被点击的li透明度变为0.8,兄弟li透明度变为0.6    
					$(this).css({'opacity':'0.8'}).siblings('li').css({'opacity':'0.6'});    
				})    
			})    
		</script>    
	</head>    
	<body>    
		<div id="tm">    
			<div class="dk">    
				<img src="../tu/t01.jpg"/>    
				<img src="../tu/t02.jpg"/>    
				<img src="../tu/t03.jpg"/>    
				<img src="../tu/t04.jpg"/>    
				<img src="../tu/t05.jpg"/>    
				<img src="../tu/t01.jpg"/>    
			</div>    
			<ul>    
				<li style="opacity: 0.8;">狂欢一夏</li>    
				<li>母婴品类日</li>    
				<li>浪的冒泡</li>    
				<li>生鲜洒水</li>    
				<li>买2免1</li>    
			</ul>    
		</div>    
	</body>    
</html>

原文链接:https://www.qiquanji.com/post/7284.html

本站声明:网站内容来源于网络,如有侵权,请联系我们,我们将及时处理。

版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。