首頁 >web前端 >js教程 >javascript實現自動左滑的輪播圖(程式碼範例)

javascript實現自動左滑的輪播圖(程式碼範例)

不言
不言轉載
2018-10-27 15:15:501923瀏覽

本篇文章帶給大家的內容是關於javascript實現自動左滑的輪播圖(程式碼範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

最近做專案總是只會調用別人做好的各種插件效果,想起很久沒來自己寫點小插件,久了會忘記的,就趕緊來補一下,前端程序員必備,實作一個js輪播圖。

html代碼:

<!DOCTYPE HTML>
<head>
    <meta charset="utf-8">
    <link rel="stylesheet" type="text/css" href="./demo.css">
</head>
 
<body>
    <div class="slide">
        <div class="img">
            <ul id="slide_img">
                <li><img src="./img/timgZQQ905MD.jpg"></li>  <!--处理无缝衔接的图片-->
                <li><img src="./img/1486293868523.jpg"></li>
                <li><img src="./img/timg1.jpg"></li>
                <li><img src="./img/timg2.jpg"></li>
                <li><img src="./img/timgZQQ905MD.jpg"></li>
            </ul>
        </div>
        <ul id="num">
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
        <div class="btn">
            <span id="left"><</span>
            <span id="right">></span>
        </div>
    </div>
    <script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
    <!--通过百度CDN地址引用jQuery库-->
    <script type="text/javascript" src="./demo.js"></script>
</body>

此次的小demo樣例用了4張圖片,由於要實現無縫銜接,即最後一張順暢地跳轉到第一張,故在寫html的時候,再重複了最後一張圖片,然後透過直接定位,在輪播到最後一張圖片的時候,將整個ul定位到第一張,由於第一張和最後一張是一樣的,故效果看起來則是順暢自然的輪播。

css程式碼:

*{
	margin: 0;
	padding: 0;
}
.slide{
	position: relative;
	width: 1000px;
	height: 500px;
	margin: 40px auto;
	overflow: hidden;
}
.img ul{
	position: absolute;
	left: -1000px;
	width: 5000px;
}
.img li{
	list-style-type: none;
	float: left;
}
img{
	width: 1000px;
	height: 500px;
}
#num li{
	list-style-type: none;
	background-color: white;
	border: 1px solid red;
	border-radius: 100px;
	float: left;
	width: 10px;
	height: 10px;
	margin: 10px;
	cursor: pointer;
}
#num {
	position: absolute;
	top: 450px;
	left: 800px;
}
.btn{
	font-size: 30px;
	color: gray;
}
#left{
	position: absolute;
	top: 230px;
	left: 40px;
	cursor: pointer;
}
#right{
	position: absolute;
	top: 230px;
	right: 40px;
	cursor: pointer;
}

 css中需要注意的是定位的時候,整個外部的p是相對定位,而裡面的內容ul則相對於外部p進行絕對定位,透過left ,top等來設定位置

js程式碼:

$(document).ready(function () {
	initRadius();
});

var number = 1;  //设置为全局变量

//轮播图图片主体
function startSlide() {
	dealRadius(number);
	if(number == 4) {
		number = 0;
		$(&#39;#slide_img&#39;).css({left: &#39;0px&#39;});  //处理无缝衔接图
		 dealRadius(0); // 处理无缝衔接小圆点的跳转
	}
	number++;
	var imageLeft = -1000 * number;
	$(&#39;#slide_img&#39;).animate({left: imageLeft});
}	
var timer = setInterval(startSlide,3000);



//小圆点的轮播实现
function dealRadius(num) {
	var lis = $(&#39;#num li&#39;);
	lis.eq(num).css(&#39;background-color&#39;, &#39;red&#39;);
	for(var i = 0; i < num; i++) {
		lis.eq(i).css(&#39;background-color&#39;,&#39;white&#39;);
	}
	for(var i = num + 1; i < 4; i++) {
		lis.eq(i).css(&#39;background-color&#39;,&#39;white&#39;);
	}
}

//初始化小圆点
function initRadius() {
	var lis = $(&#39;#num li&#39;);
	lis.eq(0).css(&#39;background-color&#39;, &#39;red&#39;);
}


//左右按钮的实现
$(&#39;#left&#39;).mousedown (function() {
	clearInterval(timer);
	if(number == 0) {
		$(&#39;#slide_img&#39;).css({left: &#39;-4000px&#39;}); 
		number = 4;
	}
	var imageLeft = -1000 * (number-1);
	$(&#39;#slide_img&#39;).animate({left: imageLeft});
	number--;
	if(number == 0) {
		dealRadius(3);
	} else {
			dealRadius(number-1);
	}
});
$(&#39;#left&#39;).mouseup(function() {
	timer = setInterval(startSlide,3000);
});

$(&#39;#right&#39;).mousedown (function() {
	clearInterval(timer);
	if(number == 4) {
		number = 0;
		$(&#39;#slide_img&#39;).css({left: &#39;0px&#39;});  //处理无缝衔接图
	}
	var imageLeft = -1000 * (number+1);
	$(&#39;#slide_img&#39;).animate({left: imageLeft});
	dealRadius(number);
	number++;

});
$(&#39;#right&#39;).mouseup(function() {
	timer = setInterval(startSlide,3000);
});


//小圆点的点击实现
$(&#39;#num&#39;).on(&#39;click&#39;,&#39;li&#39;,function(){
	clearInterval(timer);
	var _number = $(this).index() + 1;
	number = _number
	dealRadius(number-1);
	var imageLeft = -1000 * number;
	$(&#39;#slide_img&#39;).animate({left: imageLeft});
	timer = setInterval(startSlide,3000);
});

js程式碼中,首先要知道關於計時器的使用,其中,關於dom的使用,好久沒用啊,感覺很不熟悉。 。自己得多加強。 。

以上是javascript實現自動左滑的輪播圖(程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除