Heim > Web-Frontend > js-Tutorial > Vollständige Aufzeichnung des einfachen Plug-In-Produktionsprozesses für die jQuery-Fokuskartenumschaltung_jquery

Vollständige Aufzeichnung des einfachen Plug-In-Produktionsprozesses für die jQuery-Fokuskartenumschaltung_jquery

WBOY
Freigeben: 2016-05-16 16:38:32
Original
1289 Leute haben es durchsucht

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>
Nach dem Login kopieren
1. Das Umschalten von Breitbild-Fokusbildern ist jetzt beliebter, um Bilder anzuzeigen. Jetzt müssen sie durch Hintergrund als Hintergrundbild ersetzt werden, damit keine horizontalen Bildlaufleisten angezeigt werden.

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}
Nach dem Login kopieren
1. Das Höhenattribut in slide_wrap und slide kann entsprechend der tatsächlichen Situation geändert werden

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>
Nach dem Login kopieren
1. Legen Sie ul als Fokusbild-Plugin fest

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);
 };
}));
Nach dem Login kopieren
1. Das erste Semikolon soll verhindern, dass Syntaxfehler mit anderen Codes in einer Zeile kombiniert werden, wenn sie zusammen komprimiert werden. Zum Beispiel var i=0(function(factory){......}(..);

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;
 }
Nach dem Login kopieren
1. Standardwerte sind verfügbare benutzerdefinierte Parameter. Hier habe ich drei automatische Umschaltgeschwindigkeiten, Auswahlschaltflächenstile und ob sie automatisiert werden sollen

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);
  }
 } 
Nach dem Login kopieren
1. _getSlides wird verwendet, um das li-Sub-Tag des ul-Objekts abzurufen, bei dem es sich um das Focus-Map-Plug-in handelt

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;
  }
Nach dem Login kopieren
1. Fügen Sie das Button-ul-Tag dynamisch hinzu, weisen Sie ihm eine benutzerdefinierte Klasse zu und fügen Sie das Unter-Tag li hinzu

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);
  });
 }
Nach dem Login kopieren
1. Erhöhen Sie den Z-Index des aktuellen Bildes und zeigen Sie das nächste Bild an. Andernfalls wird es sehr verwirrend sein 🎜>
2. Fügen Sie der nächsten Auswahlschaltfläche einen Auswahlstil hinzu

3. Verwenden Sie FadeOut und FadeIn von jQuery, um versteckte und angezeigte Verlaufseffekte zu erstellen

8. Automatischer Zyklus

1. Bestimmen Sie, ob das Karussell angehalten oder fortgesetzt werden soll
   /**
  * @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);//暂停的时候就取消自动切换
  }
  }

Nach dem Login kopieren
2. Wenn es nicht pausiert ist, legen Sie die Seriennummern der aktuellen Seite und der Schaltfläche „Weiter“ entsprechend den Bedingungen fest

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

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