Maison > interface Web > tutoriel CSS > Comment créer des curseurs d'image jQuery simples avec des effets de fondu ou de diapositive ?

Comment créer des curseurs d'image jQuery simples avec des effets de fondu ou de diapositive ?

Linda Hamilton
Libérer: 2024-11-25 00:55:12
original
268 Les gens l'ont consulté

How to Build Simple jQuery Image Sliders with Fade or Slide Effects?

Comment créer des curseurs d'image jQuery simples avec des effets de glissement ou d'opacité

De nombreux développeurs préfèrent éviter d'utiliser des plugins prédéfinis en raison de préoccupations concernant taille ou conflits potentiels avec le JavaScript existant. Pour ceux qui préfèrent créer leurs propres sliders, voici une approche simplifiée à l'aide de jQuery :

Fonctions clés de jQuery :

  • index() : Renvoie la position d'un élément au sein de ses éléments frères.
  • eq() : Sélectionne un élément en fonction de sa position.

Approche :

  • Récupérer l'index de l'élément déclencheur sélectionné.
  • Match cet index avec l'image correspondante en utilisant le eq() méthode.

1. Fondu entrant / Fondu sortant Effet

HTML :

<ul class="images">
  ...
</ul>

<ul class="triggers">
  ...
</ul>
Copier après la connexion

CSS :

ul.images { position:relative; }
ul.images li { position:absolute; }
Copier après la connexion

jQuery :

var target;
var triggers = $('ul.triggers li');
var images = $('ul.images li');
var lastElem = triggers.length-1;

triggers.first().addClass('active');
images.hide().first().show();

function sliderResponse(target) {
    images.fadeOut(300).eq(target).fadeIn(300);
    triggers.removeClass('active').eq(target).addClass('active');
}
Copier après la connexion

2. Effet de glissement

HTML :

Idem que pour le FadeIn/FadeOut effet.

CSS :

.mask { ... }
ul.images { ... }
ul.images li { ... }
Copier après la connexion

jQuery :

var target;
var triggers = $('ul.triggers li');
var images = $('ul.images li');
var lastElem = triggers.length-1;
var mask = $('.mask ul.images');
var imgWidth = images.width();

triggers.first().addClass('active');
mask.css('width', imgWidth*(lastElem+1) +'px');

function sliderResponse(target) {
    mask.stop(true,false).animate({'left':'-'+ imgWidth*target +'px'},300);
    triggers.removeClass('active').eq(target).addClass('active');
}
Copier après la connexion

Réponse jQuery partagée pour les deux Curseurs :

triggers.click(function() { ... });
$('.next').click(function() { ... });
$('.prev').click(function() { ... });
function sliderTiming() { ... }
function resetTiming() { ... }
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal