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

May 16, 2016 pm 04:38 PM
jquery

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

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ausführliche Erläuterung der jQuery-Referenzmethoden: Kurzanleitung Ausführliche Erläuterung der jQuery-Referenzmethoden: Kurzanleitung Feb 27, 2024 pm 06:45 PM

Detaillierte Erläuterung der jQuery-Referenzmethode: Kurzanleitung jQuery ist eine beliebte JavaScript-Bibliothek, die häufig in der Website-Entwicklung verwendet wird. Sie vereinfacht die JavaScript-Programmierung und bietet Entwicklern umfangreiche Funktionen und Features. In diesem Artikel wird die Referenzmethode von jQuery ausführlich vorgestellt und spezifische Codebeispiele bereitgestellt, um den Lesern einen schnellen Einstieg zu erleichtern. Einführung in jQuery Zuerst müssen wir die jQuery-Bibliothek in die HTML-Datei einführen. Es kann über einen CDN-Link eingeführt oder heruntergeladen werden

Wie verwende ich die PUT-Anfragemethode in jQuery? Wie verwende ich die PUT-Anfragemethode in jQuery? Feb 28, 2024 pm 03:12 PM

Wie verwende ich die PUT-Anfragemethode in jQuery? In jQuery ähnelt die Methode zum Senden einer PUT-Anfrage dem Senden anderer Arten von Anfragen, Sie müssen jedoch auf einige Details und Parametereinstellungen achten. PUT-Anfragen werden normalerweise zum Aktualisieren von Ressourcen verwendet, beispielsweise zum Aktualisieren von Daten in einer Datenbank oder zum Aktualisieren von Dateien auf dem Server. Das Folgende ist ein spezifisches Codebeispiel, das die PUT-Anforderungsmethode in jQuery verwendet. Stellen Sie zunächst sicher, dass Sie die jQuery-Bibliotheksdatei einschließen. Anschließend können Sie eine PUT-Anfrage senden über: $.ajax({u

Wie entferne ich das Höhenattribut eines Elements mit jQuery? Wie entferne ich das Höhenattribut eines Elements mit jQuery? Feb 28, 2024 am 08:39 AM

Wie entferne ich das Höhenattribut eines Elements mit jQuery? Bei der Front-End-Entwicklung müssen wir häufig die Höhenattribute von Elementen manipulieren. Manchmal müssen wir möglicherweise die Höhe eines Elements dynamisch ändern, und manchmal müssen wir das Höhenattribut eines Elements entfernen. In diesem Artikel wird erläutert, wie Sie mit jQuery das Höhenattribut eines Elements entfernen, und es werden spezifische Codebeispiele bereitgestellt. Bevor wir jQuery zum Betreiben des Höhenattributs verwenden, müssen wir zunächst das Höhenattribut in CSS verstehen. Das Höhenattribut wird verwendet, um die Höhe eines Elements festzulegen

jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite Feb 28, 2024 pm 09:06 PM

Titel: jQuery-Tipps: Ändern Sie schnell den Text aller Tags auf der Seite. In der Webentwicklung müssen wir häufig Elemente auf der Seite ändern und bedienen. Wenn Sie jQuery verwenden, müssen Sie manchmal den Textinhalt aller a-Tags auf der Seite gleichzeitig ändern, was Zeit und Energie sparen kann. Im Folgenden wird erläutert, wie Sie mit jQuery den Text aller Tags auf der Seite schnell ändern können, und es werden spezifische Codebeispiele angegeben. Zuerst müssen wir die jQuery-Bibliotheksdatei einführen und sicherstellen, dass der folgende Code in die Seite eingefügt wird: &lt

Eingehende Analyse: Vor- und Nachteile von jQuery Eingehende Analyse: Vor- und Nachteile von jQuery Feb 27, 2024 pm 05:18 PM

jQuery ist eine schnelle, kleine und funktionsreiche JavaScript-Bibliothek, die häufig in der Front-End-Entwicklung verwendet wird. Seit seiner Veröffentlichung im Jahr 2006 ist jQuery für viele Entwickler zu einem der bevorzugten Tools geworden, hat in der Praxis jedoch auch einige Vor- und Nachteile. In diesem Artikel werden die Vor- und Nachteile von jQuery eingehend analysiert und anhand spezifischer Codebeispiele veranschaulicht. Vorteile: 1. Prägnante Syntax Das Syntaxdesign von jQuery ist prägnant und klar, was die Lesbarkeit und Schreibeffizienz des Codes erheblich verbessern kann. Zum Beispiel,

Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern Feb 28, 2024 pm 05:42 PM

Titel: Verwenden Sie jQuery, um den Textinhalt aller Tags zu ändern. jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur Verarbeitung von DOM-Operationen verwendet wird. Bei der Webentwicklung müssen wir häufig den Textinhalt des Link-Tags (eines Tags) auf der Seite ändern. In diesem Artikel wird erläutert, wie Sie mit jQuery dieses Ziel erreichen, und es werden spezifische Codebeispiele bereitgestellt. Zuerst müssen wir die jQuery-Bibliothek in die Seite einführen. Fügen Sie den folgenden Code in die HTML-Datei ein:

Verstehen Sie die Rolle und Anwendungsszenarien von eq in jQuery Verstehen Sie die Rolle und Anwendungsszenarien von eq in jQuery Feb 28, 2024 pm 01:15 PM

jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur DOM-Manipulation und Ereignisbehandlung in Webseiten verwendet wird. In jQuery wird die Methode eq() verwendet, um Elemente an einer bestimmten Indexposition auszuwählen. Die spezifischen Verwendungs- und Anwendungsszenarien sind wie folgt. In jQuery wählt die Methode eq() das Element an einer angegebenen Indexposition aus. Indexpositionen beginnen bei 0 zu zählen, d. h. der Index des ersten Elements ist 0, der Index des zweiten Elements ist 1 und so weiter. Die Syntax der eq()-Methode lautet wie folgt: $("s

Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Feb 29, 2024 am 09:03 AM

Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Wenn Sie jQuery zum Betreiben von DOM-Elementen verwenden, stoßen Sie häufig auf Situationen, in denen Sie feststellen müssen, ob ein Element ein bestimmtes Attribut hat. In diesem Fall können wir diese Funktion einfach mit Hilfe der von jQuery bereitgestellten Methoden implementieren. Im Folgenden werden zwei häufig verwendete Methoden vorgestellt, um festzustellen, ob ein jQuery-Element über bestimmte Attribute verfügt, und um spezifische Codebeispiele anzuhängen. Methode 1: Verwenden Sie die Methode attr() und den Operator typeof //, um zu bestimmen, ob das Element ein bestimmtes Attribut hat

See all articles