Die Homepage benötigt oft einen Fokusbild-Umschalteffekt, und die jüngsten Projekte erfordern ihn auch, also habe ich online gesucht und ein halbfertiges Plug-In gefunden, das ich selbst modifiziert habe.
Unter dem js-Ordner befinden sich zwei Ordner, jquery.jslide.js und jquery.jslides.js. Der erste wurde von mir neu geschrieben und der zweite ist die Datei des ursprünglichen Autors. Das Bild unten ist das Rendering:
1. Statischer Effekt
<div class="slide_wrap"> <ul id="slides2" class="slide"> <li style="background:url('images/01.jpg') no-repeat center top"><a href="http://www.jb51.net/" target="_blank">pwstrick1</a></li> <li style="background:url('images/02.jpg') no-repeat center top"><a href="http://www.jb51.net/" target="_blank">pwstrick2</a></li> <li style="background:url('images/03.jpg') no-repeat center top"><a href="http://www.jb51.net/" target="_blank">pwstrick3</a></li> <li style="background:url('images/04.jpg') no-repeat center top"><a href="http://www.jb51.net/" target="_blank">pwstrick4</a></li> </ul> </div>
2. Legen Sie einen slide_wrap auf der äußersten Oberfläche fest, um die absolute Positionierung der Bilder im Inneren zu begrenzen
Ich habe die Klasse ursprünglich in 3.ul hinzugefügt, als das Plug-in initialisiert wurde. Der Anzeigeeffekt ist besser als das spätere Hinzufügen. Sie können Änderungen vornehmen, wenn Sie das Plug-in neu schreiben >
.slide_wrap {width:100%;height:400px;position:relative} .slide_wrap .slide { display:block; width:100%; height:400px; list-style:none; padding:0; margin:0; position:relative;} .slide_wrap .slide li { display:block; width:100%; height:100%; list-style:none; padding:0; margin:0; position:absolute;} .slide_wrap .slide li a { display:block; width:100%; height:100%; text-indent:-9999px;} .slide_wrap .pagination { display:block; list-style:none; position:absolute; left:50%; top:340px; z-index:9900;padding:5px 15px 5px 0; margin:0} .slide_wrap .pagination li { display:block; list-style:none; width:10px; height:10px; float:left;margin-left:15px; border-radius:5px; background:#FFF } .slide_wrap .pagination li a { display:block; width:100%; height:100%; padding:0; margin:0; text-indent:-9999px;outline:0} .slide_wrap .pagination li.current { background:#0092CE}
2. Paginierung ist der Schaltflächenstil im Bild. Er wird verwendet, um zu steuern, welches Bild links und oben angezeigt wird, und kann je nach tatsächlicher Situation geändert werden
3. Jede Farbe im Stil kann auch entsprechend dem gewünschten Effekt angepasst werden
4. Der obige Stil ist etwas ausführlicher. Er kann entsprechend vereinfacht werden, wenn er in Ihr eigenes Projekt eingebettet wird
2. Aufrufmethode
<script type="text/javascript"> $('#slides2').jslide(); </script>
2. Jede der folgenden Operationen dreht sich um ul
3. Gemeinsames Format des jQuery-Plug-ins
;(function (factory) { 'use strict'; // Register as an AMD module, compatible with script loaders like RequireJS. if (typeof define === 'function' && define.amd) { define(['jquery'], factory); } else { factory(jQuery); } }(function ($, undefined) { 'use strict'; //中间插件代码 $.fn.jslide = function (method) { return _init.apply(this, arguments); }; }));
2. „use strict“ aktiviert den strikten Modus, sodass der Javascript-Interpreter die „strikte“ Syntax verwenden kann, um den Code zu analysieren, um Entwicklern bei der Fehlersuche zu helfen
3. Wenn das Requirejs-Modul zum Laden des Frameworks verwendet wird, sorgt define(['jquery'], Factory) dafür, dass das Plug-in die AMD-Spezifikation unterstützt
4. Funktion ($, undefiniert) Das Undefinierte hier soll die Verwendung von neu geschriebenen undefinierten Dateien beim Einführen anderer js-Dateien verhindern
5. _init wird für den Initialisierungseffekt verwendet
4. Plug-in-Initialisierung
var defaults = { speed : 3000, pageCss : 'pagination', auto: true //自动切换 }; var nowImage = 0;//现在是哪张图片 var pause = false;//暂停 var autoMethod; /** * @method private * @name _init * @description Initializes plugin * @param opts [object] "Initialization options" */ function _init(opts) { opts = $.extend({}, defaults, opts || {}); // Apply to each element var $items = $(this); for (var i = 0, count = $items.length; i < count; i++) { _build($items.eq(i), opts); } return $items; }
2. Drei globale Parameter: nowImage ist die Seriennummer des aktuell angezeigten Bildes, pause steuert, ob das Bild umgeschaltet oder angehalten wird, und autoMethod ist die Nummer der Timing-Funktion
3. Benutzerdefinierte Parameter werden in _init zusammengeführt und _build wird aufgerufen, um die Operation zu erstellen
5. Verschiedene Vorgänge zum Erstellen eines Plug-Ins
/** * @method private * @name _getSlides * @description 获取幻灯片对象 * @param $node [jQuery object] "目标对象" */ function _getSlides($node) { return $node.children('li'); } /** * @method private * @name _build * @description Builds each instance * @param $node [jQuery object] "目标对象" * @param opts [object] "插件参数" */ function _build($node, opts) { var $slides = _getSlides($node); $slides.eq(0).siblings('li').css({'display':'none'}); var numpic = $slides.size() - 1; $node.delegate('li', 'mouseenter', function() { pause = true;//暂停轮播 clearInterval(autoMethod); }).delegate('li', 'mouseleave', function() { pause = false; autoMethod = setInterval(function() { _auto($slides, $pages, opts); }, opts.speed); }); //console.log(autoMethod) var $pages = _pagination($node, opts, numpic); if(opts.auto) { autoMethod = setInterval(function() { _auto($slides, $pages, opts); }, opts.speed); } }
2. Legen Sie andere Tags außer dem ersten li-Tag fest, die ausgeblendet werden sollen
3. Da die nachfolgende Schleife bei Index 0 beginnt und die Operation <= ausführt, ist es in der Tat in Ordnung, hier nicht zu subtrahieren.
4. Legen Sie die Ereignisse „mouseenter“ und „mouseleave“ für das li-Tag fest, die die Schleife abbrechen bzw. fortsetzen sollen
5. Schaltfläche zur Initialisierungsauswahl
6. Wenn der Parameter auto wahr ist, wird die automatische Umschaltung aktiviert
6. Schaltfläche zur Initialisierungsauswahl
/** * @method private * @name _pagination * @description 初始化选择按钮 * @param $node [jQuery object] "目标对象" * @param opts [Object] "参数" * @param size [int] "图片数量" */ function _pagination($node, opts, size) { var $ul = $('<ul>', {'class': opts.pageCss}); for(var i = 0; i <= size; i++){ $ul.append('<li>' + '<a href="javascript:void(0)">' + (i+1) + '</a>' + '</li>'); } $ul.children(':first').addClass('current');//给第一个按钮选中样式 var $pages = $ul.children('li'); $ul.delegate('li', 'click', function() {//绑定click事件 var changenow = $(this).index(); _changePage($pages, $node, changenow); }).delegate('li', 'mouseenter', function() { pause = true;//暂停轮播 }).delegate('li', 'mouseleave', function() { pause = false; }); $node.after($ul); return $pages; }
2. Fügen Sie der ersten Schaltfläche einen Auswahlstil hinzu
3. Fügen Sie dem li-Tag Click-, MouseEnter- und Mouseleave-Ereignisse hinzu und binden Sie das Click-Ereignis an den Schaltvorgang
4. Platzieren Sie den Paging-Button hinter dem Plug-in-Objekt ul
5. Kehren Sie zum Li-Objekt in der Paging-Schaltfläche zurück, was später nützlich sein wird
7. Bilder wechseln
/** * @method private * @name _change * @description 幻灯片显示与影藏 * @param $slides [jQuery object] "图片对象" * @param $pages [jQuery object] "按钮对象" * @param next [int] "要显示的下一个序号" */ function _fadeinout($slides, $pages, next){ $slides.eq(nowImage).css('z-index','2'); $slides.eq(next).css({'z-index':'1'}).show(); $pages.eq(next).addClass('current').siblings().removeClass('current'); $slides.eq(nowImage).fadeOut(400, function(){ $slides.eq(next).fadeIn(500); }); }
3. Verwenden Sie FadeOut und FadeIn von jQuery, um versteckte und angezeigte Verlaufseffekte zu erstellen
8. Automatischer Zyklus
/** * @method private * @name _auto * @description 自动轮播 * @param $slides [jQuery object] "图片对象" * @param $pages [jQuery object] "按钮对象" * @param opts [Object] "参数" */ function _auto($slides, $pages, opts){ var next = nowImage + 1; var size = $slides.size() - 1; if(!pause) { if(nowImage >= size){ next = 0; } _fadeinout($slides, $pages, next); if(nowImage < size){ nowImage += 1; }else { nowImage = 0; } }else { clearInterval(autoMethod);//暂停的时候就取消自动切换 } }
Es gibt immer noch viele Probleme mit dem Plug-in, z. B. die Unfähigkeit, zwei verschiedene Objekte auf einer Seite zu binden, und es gibt viel Raum für Änderungen.
Durch diese Modifikation habe ich ein steuerbares Plug-in zum Umschalten der Fokuskarte. Obwohl es immer noch viele Probleme gibt, können diese Schritt für Schritt gelöst werden. Es wird in Zukunft viel bequemer sein, es in Ihr eigenes Projekt einzubetten.
Demo:
http://demo.jb51.net/js/2014/jsilde/
Download: http://www.jb51.net/jiaoben/210405.html