亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js實現(xiàn)無縫輪播圖插件封裝

 更新時間:2020年07月31日 17:01:52   作者:河南云和數(shù)據(jù)  
這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)無縫輪播圖插件封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言:頁面中輪播圖,對于一個前端開發(fā)者來說,是最基本的技能,不論是的商城網(wǎng)站,還是企業(yè)站,輪播圖已經(jīng)成為不可缺少的一個模塊,而常見的輪播圖不外乎兩種,一種是漸隱漸現(xiàn)輪播圖,一種是無縫輪播圖。網(wǎng)上關(guān)于輪播圖的件也有很多,但是用人家的代碼總會出現(xiàn)各種各樣的bug,我們修改bug往往要耗費很多時間,而且有些插件的效果還不符合我們的需求,那么我們該如何封裝一個自己的輪播插件呢?這就是我們今天的任務(wù),封裝輪播插件。

1、特效離不開合理的頁面布局,所以我們首先需要進(jìn)行頁面布局:

HTML代碼:

<div class="container mycontainer">
 <div class="wrapper">
 <div class="slide">
  <img src="image/jd01.jpg" alt="">
 </div>
 <div class="slide">
  <img src="image/jd02.jpg" alt="">
 </div>
 <div class="slide">
  <img src="image/jd03.jpg" alt="">
 </div>
 <div class="slide">
  <img src="image/jd04.jpg" alt="">
 </div>
 </div>
 <!-- 分頁器 -->
 <ul class="pagination"></ul>
 <!-- 導(dǎo)航按鈕 -->
 <div class="button-pre"></div>
 <div class="button-next"></div>
</div>

2、在HTML頁面中引入css樣式文件:css樣式文件代碼如下:

CSS代碼:

* {
 margin: 0;
 padding: 0;
}

ul,
li {
 list-style: none;
}

.container { 
 margin: 200px auto;
 position: relative;
 overflow: hidden;
}

.slide {
 float: left;
}

img {
 display: block;
}

.pagination {
 width: 160px;
 position: absolute;
 bottom: 30px;
 margin-left: -80px;
 left: 50%;
}

.pagination li {
 float: left;
 width: 20px;
 height: 20px;
 background-color: blue;
 margin: 0 10px;
 border-radius: 50%;
}

.button-pre,
.button-next {
 width: 22px;
 height: 40px;
 position: absolute;
 top: 50%;
 margin-top: -20px;
}

.button-pre {
 left: 30px;
 background: url('../image/left.png') no-repeat center center;
}

.button-next {
 right: 30px;
 background: url('../image/right.png') no-repeat center center;
}

.pagination .active {
 background-color: red;
}
.mycontainer{
 width: 590px;
 height: 470px;
}

頁面布局完成后,接下來就是javaScript代碼,綁定事件;

在綁定事件之前,我們首先要知道無縫輪播圖的原理和一些技術(shù)關(guān)鍵點。
輪播圖的原理:最外層視野區(qū)域固定大小且的溢出隱藏,通過動態(tài)控制包裹圖片的父元素的marginLeft值實現(xiàn)輪播;
關(guān)鍵點1:最外層的盒子container固定大小,是我們的視野區(qū)域,需要設(shè)置溢出隱藏overflow:hidden;
關(guān)鍵點2:所有輪播的圖片使用一個共同的父元素wrapper包裹起來;
關(guān)鍵點3:動態(tài)克隆第一張圖片所在的元素silde,然后添加到最后;
關(guān)鍵點4:父元素wrapper的寬度為圖片個數(shù)(原始圖片個數(shù)+1,因為克隆多添加了一張圖片)乘以單獨一張圖片的寬度;
關(guān)鍵點5:實現(xiàn)無縫輪播的判斷條件,marginleft樣式重置時機;
關(guān)鍵點6:動態(tài)生成分頁器按鈕,并設(shè)置分頁器pagination樣式;
關(guān)鍵點7:實現(xiàn)自動播放和清除播放,使用計時器setInterval()和 clearInterval()
關(guān)鍵點8:實現(xiàn)代碼復(fù)用,借助面向?qū)ο蟮拈_發(fā)——構(gòu)造函數(shù)+原型對象+jQuery插件封裝機制實現(xiàn)

3、關(guān)鍵點梳理完之后,就可以開始javascript代碼:通過自執(zhí)行函數(shù)實現(xiàn);需要在HTML頁面引入JS文件,JS文件代碼如下:

JS代碼:

;(function($){
 // 默認(rèn)設(shè)置
 var defaults = {
 speed:1000,
 interval:2000
 }
 function Banner(ele,options){
 // 獲取元素對象
 this.element = $(ele);
 // 合并設(shè)置項
 this.options = $.extend({},defaults,options);
 // 獲取包裹圖片的父元素
 this.wrapper = this.element.children().first();
 // 獲取要克隆的元素
 this.firstChild = this.wrapper.find('.slide:first');
 // 獲取一張圖片寬度
 this.Width = this.firstChild.width();
 // 記錄圖片下標(biāo)
 this.n = 0;
 // 獲取圖片個數(shù)
 this.len = this.wrapper.find('.slide').length;
 // 獲取切換導(dǎo)航按鈕
 this.prev = this.element.find('.button-pre');
 this.next = this.element.find('.button-next');
 // 獲取分頁器
 this.pagination = this.element.find('.pagination');
 // 計時器
 this.timer = null;
 }
 // 初始化
 Banner.prototype.init = function(){
 var self = this; 
 (function () {
  // 克隆第一張圖片并添加到元素的最后邊,設(shè)置包裹圖片父盒子的寬度
  self.wrapper.append(self.firstChild.clone(true));
  self.wrapper.css({ width:self.Width * (self.len + 1)});
  // 生成對應(yīng)的分頁器按鈕
  for(var i = 0; i < self.len; i++){
  $('<li></li>').appendTo(self.pagination); 
  }
  // 動態(tài)設(shè)置分頁器的樣式
  self.pagination.find('li:first').addClass('active');
  var btnWidth = self.pagination.find('li:first').outerWidth(true) * self.len;
  self.pagination.css({width:btnWidth,marginLeft:-btnWidth / 2})
 })() 
 // 調(diào)用所有綁定的事件
 this.nextClick(); 
 this.preClick(); 
 this.btnClick();
 this.autoPlay();
 this.clearPlay(this.element);
 }
 // 切換下一張圖片事件
 Banner.prototype.nextClick = function(){
 var self = this;
 this.next.click(function(){
  self.moveNext();
 })
 }
 // 切換圖片,同時也為實現(xiàn)自動播放
 Banner.prototype.moveNext = function() {
 this.n++;
 // 判斷重置時機和重置樣式
 if (this.n > this.len ) {
  this.n = 1;
  this.wrapper.css({ marginLeft: 0 });
 }
 this.changeBtn(this.n > 3 ? 0 : this.n);
 this.wrapper.stop(true,true).animate({ marginLeft: -this.Width * this.n }, this.options.speed)
 }

 // 點擊切換上一張圖片
 Banner.prototype.preClick = function(){
 var self = this;
 this.prev.click(function () {
  self.n--;
  if (self.n < 0) {
  self.n = self.len - 1;
  self.wrapper.css({ marginLeft: -(self.len) * self.Width });
  }
  self.changeBtn(self.n < 0 ? self.n = 3 : self.n);
  self.wrapper.animate({ marginLeft: -self.Width * self.n }, self.options.speed)
 })
 }
 // 點擊分頁器切換圖片
 Banner.prototype.btnClick = function(){
 var self = this;  
  this.pagination.find('li').click(function () {
  var index = $(this).index();
  self.n = index;
  self.changeBtn(index);
  self.wrapper.animate({ marginLeft: -self.Width * index }, self.options.speed)
 })
 }
 // 動態(tài)修改分頁器按鈕的樣式
 Banner.prototype.changeBtn = function(index){
 this.pagination.find('li').eq(index).addClass('active').siblings().removeClass('active');
 }
 // 自動輪播
 Banner.prototype.autoPlay = function(){
 var self = this;
 /* 計時器中調(diào)用函數(shù)是,函數(shù)中的this 指向 window, 所以需要使用self.timer = setInterval(function(){
  self.moveNext();
  },2000);
  不能直接使用 self.timer = setInterval(self.moveNext(),2000); 形式 */
 self.timer = setInterval(function(){
  self.moveNext();
 },self.options.interval);
 }
 // 清除自動播放
 Banner.prototype.clearPlay = function(ele){
 var self = this;
 ele.mouseenter(function(){
  clearInterval(self.timer)
 }).mouseleave(function(){
  // 再次開啟自動輪播
  self.timer = setInterval(function(){
  self.moveNext();
  },self.options.interval);
 })
 }
 // jQuery插件實現(xiàn)
$.fn.myBanner = function(params){
 // params 是自定義的配置項
 var banner = new Banner(this,params);
 banner.init();
 // 如果需要鏈?zhǔn)秸{(diào)用
 return this;
 }
})(jQuery)

最后在HTML頁面中進(jìn)行初始化,最好放到HTML結(jié)束標(biāo)簽之前的位置,因為我們封裝的插件是依賴于jQuery的,因此首先引入jQuery文件,然后在引入我們自己封裝的js文件;最后就是進(jìn)行初始化設(shè)置:

<script>
 $(function(){
  $('.mycontainer').myBanner({
  // speed:圖片切換速度
  // interval:圖片切換的時間間隔
  speed:500,
  interval:3000
  });
 })
 

</script>

到此為止,我們已經(jīng)實現(xiàn)了輪播插件的封裝并且實現(xiàn)了復(fù)用,只需要動態(tài)的綁定不同的元素mycontainer(可以動態(tài)修改成自己的元素名字)即可實現(xiàn)復(fù)用。

4、如果需要修改容器的大小和圖片的大小,可以直接覆蓋樣式即可:

.mycontainer2{
 width: 300px;
 height:200px;
}
.mycontainer2 img{
 width: 300px;
 height:200px;
}

5、完成。恭喜你,你的輪播插件可以正常切換了

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • js離開或刷新頁面檢測(且兼容FF,IE,Chrome)

    js離開或刷新頁面檢測(且兼容FF,IE,Chrome)

    這篇文章主要介紹了js離開或刷新頁面檢測(且兼容FF,IE,Chrome)。需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • var與Javascript變量隱式聲明

    var與Javascript變量隱式聲明

    在JavaScript中,var用來聲明變量,但是這個語法并不嚴(yán)格要求,很多時修改,我們可以直接使用一個變量而不用var聲明它。
    2009-09-09
  • JS判斷當(dāng)前頁面是否在微信瀏覽器打開的方法

    JS判斷當(dāng)前頁面是否在微信瀏覽器打開的方法

    這篇文章主要介紹了JS判斷當(dāng)前頁面是否在微信瀏覽器打開的方法,涉及JavaScript針對客戶端的相關(guān)判定技巧,非常簡單實用,需要的朋友可以參考下
    2015-12-12
  • Bootstrap框架實現(xiàn)廣告輪播效果

    Bootstrap框架實現(xiàn)廣告輪播效果

    這篇文章主要為大家詳細(xì)介紹了Bootstrap框架結(jié)合JavaScript實現(xiàn)廣告輪播特效,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 詳解小程序之簡單登錄注冊表單驗證

    詳解小程序之簡單登錄注冊表單驗證

    這篇文章主要介紹了小程序之簡單登錄注冊表單驗證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • 一個css與js結(jié)合的下拉菜單支持主流瀏覽器

    一個css與js結(jié)合的下拉菜單支持主流瀏覽器

    這是一個css和js結(jié)合的下拉菜單,經(jīng)測試支持主流瀏覽器,比較適合企業(yè)站,需要的朋友可以參考下
    2014-10-10
  • 微信小程序視圖容器(swiper)組件創(chuàng)建輪播圖

    微信小程序視圖容器(swiper)組件創(chuàng)建輪播圖

    這篇文章主要為大家詳細(xì)介紹了微信小程序視圖容器(swiper)組件創(chuàng)建輪播圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 在JS中最??吹角凶钊菀酌曰蟮恼Z法(轉(zhuǎn))

    在JS中最??吹角凶钊菀酌曰蟮恼Z法(轉(zhuǎn))

    發(fā)現(xiàn)一篇JS中比較容易迷惑的語法的解釋,挺有用的,轉(zhuǎn)載下,與大家分享
    2010-10-10
  • 淺析Promise的介紹及基本用法

    淺析Promise的介紹及基本用法

    Promise是異步編程的一種解決方案,在ES6中Promise被列為了正式規(guī)范,統(tǒng)一了用法,原生提供了Promise對象。接下來通過本文給大家介紹Promise的介紹及基本用法,感興趣的朋友一起看看吧
    2021-10-10
  • RequireJS用法簡單示例

    RequireJS用法簡單示例

    這篇文章主要介紹了RequireJS用法,結(jié)合簡單實例形式分析了RequireJS項目文件結(jié)構(gòu)、相關(guān)操作技巧與注意事項,需要的朋友可以參考下
    2018-08-08

最新評論