Heim > Web-Frontend > js-Tutorial > Plug-in-Kapselung des JS-Karusselldiagramms

Plug-in-Kapselung des JS-Karusselldiagramms

巴扎黑
Freigeben: 2017-07-18 17:07:11
Original
1398 Leute haben es durchsucht

Heutzutage gibt es oft Bilderkarusselleffekte im Internet. Sie haben alle möglichen Effekte, die ich selbst geschrieben habe. Wiedergabeeffekt

Diese Lightbox verfügt über einen Fenstercontainer. Im Container befindet sich ein langer Container, der alle Bilder horizontal abdeckt. Der linke und rechte Effekt wird durch Ändern des linken Rands erreicht.

Unter dem Bild befindet sich ein schwarzes Quadrat, das der Anzahl der Bilder entspricht. Klicken Sie auf das schwarze Quadrat, um zum entsprechenden Bild zu springen.

Das größte Merkmal dieses Plug-Ins ist, dass es dies kann Wenn Sie zum letzten Bild wechseln, klicken Sie erneut auf die Schaltfläche rechts. Das erste Bild wird auf der rechten Seite angezeigt, wodurch eine Endloswiedergabe erreicht wird.

Ich hatte keine Zeit, den Stil des Bildes und der Schaltfläche zu debuggen. Sie können das CSS entsprechend dem gewünschten Effekt ändern

Der spezifische Code lautet wie folgt:

~function(){function AutoBanner(curEleId,ajaxURL,interval){//把之前存储获取元素的变量都作为当前实例的私有属性this.banner = document.getElementById(curEleId);this.bannerInner = utils.firstChild(this.banner);this.bannerTip = utils.children(this.banner,"ul")[0];this.bannerLink = utils.children(this.banner,'a');this.bannerLeft = this.bannerLink[0];this.bannerRight = this.bannerLink[1];this.divList = this.bannerInner.getElementsByTagName('div');this.imgList = this.bannerInner.getElementsByTagName('img');this.oLis = this.bannerTip.getElementsByTagName('li');//之前的全局变量也应该变为自己的私有属性this.jsonData = null;this.interval = interval || 3000;this.autoTimer = null;this.step = 0;this.ajaxURL = ajaxURL;//返回当前实例return this.init();
    }

    AutoBanner.prototype = {
        constructor:AutoBanner,//Ajax请求数据getData:function(){var _this = this;var xhr = new XMLHttpRequest;
            xhr.open("get",this.ajaxURL + "?_="+Math.random(),false);
            xhr.onreadystatechange = function(){if(xhr.readyState ===4 && /^2\d{2}$/.test(xhr.status)){
                    _this.jsonData = utils.formatJSON(xhr.responseText)
                }
            }
            xhr.send(null)
        },//实现数据绑定bindData:function(){var str = "",str2 = "";if(this.jsonData){for(var i = 0,len=this.jsonData.length;i<len;i++){var curData = this.jsonData[i];
                    str+=&#39;<div><img src="" alt="" trueImg="&#39;+curData[&#39;img&#39;]+&#39;"></div>';
                    i===0?str2+="<li class=&#39;bg&#39;></li>":str2+="<li></li>"}
            }this.bannerInner.innerHTMl = str;this.bannerTip.innerHTML = str2;
        },//延迟加载lazyImg:function(){var _this = this;for(var i = 0,len = this.imgList.length;i<len;i++){~function(i){var curImg = _this.imgList[i];var oImg = new Image;
                    oImg.src = curImg.getAttribute('trueImg');
                    oImg.onload = function(){
                        curImg.src = this.src;
                        curImg.style.display = block;//只对第一张处理if(i===0){var curDiv = curImg.parentNode;
                            curDiv.style.zIndex = 1;
                            myAnimate(curDiv,{opacity:1},200);
                        }
                        oImg = null;
                    }
                }(i)
            }
        },//自动轮播autoMove:function(){if(this.step === this.jsonData.length-1){this.step = -1}this.step++;this.setBanner();
        },//切换效果和焦点对齐setBanner:function(){for(var i = 0,len = this.divList.length;i<len;i++){var curDiv = this.divList[i];if(i===this.step){
                    utils.css(curDiv,"zIndex",1)//2、让当前的透明度从0变为1,当动画结束,我们需要让其他的div的透明度的值直接变为0myAnimate(curDiv,{opacity:1},200,function(){var curDivSib = utils.siblings(this);for(var k = 0,len = curDivSib.length;k<len;k++){
                            utils.css(curDivSib[k],'opacity',0)
                        }

                    })continue}
                utils.css(curDiv,"zIndex",0)
            }//实现焦点对其for(i = 0,len = this.oLis.length;i<len;i++){var curLi = this.oLis[i];
                i === this.step?utils.addClass(curLi,"bg"):utils.removeClass(curLi,"bg");
            }
        },//控制自动轮播mouseEvent:function(){var _this = this;this.banner.onmouseover = function(){
                window.clearInterval(_this.autoTimer);
                _this.bannerLeft.style.display = _this.bannerRight.style.display = "block"}this.banner.onmouseout = function(){
                _this.autoTimer = window.setInterval(function(){
                    _this.autoMove.call(_this)
                },_this.interval);
                _this.bannerLeft.style.display = _this.bannerRight.style.display = "none"}
        },//实现焦点切换tipEvent:function(){var _this = this;for(var i = 0,len = this.oLis.length;i<len;i++){var curLi = this.oLis[i];
                curLi.index = i;
                curLi.onclick = function(){
                    _this.step = this.index;
                    _this.setBanner();
                }
            }
        },//实现左右切换leftRight:function(){var _this = this;this.bannerRight.onclick = function(){
                _this.autoMove();
            };this.bannerLeft.onclick = function(){if(_this.step === 0){
                    _this.step = _this.jsonData.length;
                }
                _this.step--;
                _this.setBanner();
            }
        },//当前插件的唯一入口  命令模式:init相当于指挥室,指挥各军队协同作战init:function(){var _this = this;this.getData();this.bindData();
            window.setTimeout(function(){
                _this.lazyImg();
            },500);this.autoTimer = window.setInterval(function(){
                _this.autoMove();
            },this.interval);this.mouseEvent();this.tipEvent();this.leftRight();return this;
        }

    }

    window.AutoBanner = AutoBanner
}()//使用var banner1 = new AutoBanner('banner','json/banner.txt',1000)
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonPlug-in-Kapselung des JS-Karusselldiagramms. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage