요즘 웹사이트에는 사진 회전판 효과가 있는 경우가 많습니다. 인터넷에는 다양한 효과가 있는 사진 회전판 플러그인도 있습니다. 여기에는 제가 직접 작성한 사진 회전판 효과가 있습니다. 창 컨테이너이며 컨테이너 내부에는 모든 그림을 가로로 감싸는 긴 컨테이너가 있습니다. 왼쪽 여백을 변경하면 왼쪽 및 오른쪽 효과가 달성됩니다.
사진 아래에 사진 수에 해당하는 검은색 사각형이 있습니다. 검은색 사각형을 클릭하면 해당 사진으로 이동합니다.
이 플러그인의 가장 큰 특징은 사진 수에 따라 전환할 수 있다는 것입니다. 안쪽으로 밀어서 끝까지 슬라이드하면 사진이 표시될 때 오른쪽에 있는 버튼을 다시 클릭하면 첫 번째 사진이 오른쪽에 나타나 루프 재생이 됩니다.
그림과 버튼의 스타일을 디버깅할 시간이 없었습니다. 원하는 효과에 따라 CSS를 변경할 수 있습니다.
구체적인 코드는 다음과 같습니다.
~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+='<div><img src="" alt="" trueImg="'+curData['img']+'"></div>'; i===0?str2+="<li class='bg'></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)
위 내용은 JS 캐러셀 차트의 플러그인 캡슐화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!