Maison >interface Web >js tutoriel >Comment écrire une image de carrousel jquery

Comment écrire une image de carrousel jquery

藏色散人
藏色散人original
2020-12-08 10:28:004486parcourir

Comment implémenter le carrousel jquery : créez d'abord une boîte placée "p.focus" ; puis définissez le débordement sur caché puis utilisez javascript pour réaliser la fonction de clic gauche et droit pour changer d'image.

Comment écrire une image de carrousel jquery

L'environnement d'exploitation de ce tutoriel : système Windows7, jquery1 Version .10.0, ordinateur Dell G3.

Recommandé : "Tutoriel vidéo jquery" "Tutoriel de base javascript"

jQuery pour obtenir un effet carrousel

De nombreux sites Web ou portails de commerce électronique auront une publicité qui fait pivoter automatiquement l'image de focus. Ci-dessous, j'utiliserai jQuery pour obtenir cet effet moi-même.
Comment écrire une image de carrousel jquery
Il y a trois fonctions principales qui doivent être mises en œuvre :
1. Cliquez pour tourner la page à gauche et à droite, et les images changeront
2. Cliquez sur le bouton de navigation ci-dessous , et les images à cet emplacement seront affichées
3 . Lorsque la souris quitte la zone, les boutons de rotation de page gauche et droite disparaissent et les images pivotent automatiquement

Écriture HTML

<.>Tout d'abord, vous avez besoin d'une boîte placée p.focus. La largeur et la hauteur de cette boîte doivent être les mêmes que chacune. Gardez la taille des images cohérente et définissez le débordement sur caché. La largeur de l'image est la largeur totale de toutes les images, et le changement d'image est obtenu en modifiant l'attribut gauche de la boîte. Parce que lorsque vous cliquez sur la dernière image puis sur l'image suivante, vous devez passer à la première image pour obtenir l'effet de défilement infini, ajoutez donc une autre image au début et à la fin.


Comment écrire une image de carrousel jquery
Comment écrire une image de carrousel jquery Vous pouvez voir que si l'attribut overflow de p.focus est commenté, l'image sera en mosaïque sur toute la page.

Écriture CSS

Étant donné que l'attribut gauche de l'image doit être modifié, sa position doit être définie sur absolue. Les boutons de page gauche et droit changent de transparence lorsque la souris passe dessus.

Écriture JavaScript

Tout d'abord, vous devez réaliser la fonction de cliquer à gauche et à droite pour tourner les pages et changer d'image

La largeur d'une image est de 480 pixels, donc lorsque vous cliquez sur la flèche à droite, l'image doit être déplacée vers Déplacer 480 px vers la gauche signifie que la gauche sera réduite de 480 px, et lorsque vous cliquez sur la flèche gauche, la gauche sera augmentée de 480 px en même temps ; , lorsque l'image passe de la dernière à la première, la valeur de gauche doit être réinitialisée à -480px, dès la première Lors du passage à la dernière image, réinitialisez la valeur de gauche à -2880px, ce qui crée l'illusion d'une boucle infinie .

 /**
  * 这个函数用于移动图片,接收一个移动参数
  * @param dis为需要移动的距离
  */
  function move(dis){
    moving = true;    let $picture = $(".picture");    let left = parseInt($picture.css("left"));
    left += dis;
    $picture.animate({left:left},400,"linear",function(){
      if(left > -480){
        left = -2880;
      }      if(left < -2880){
        left = -480;
      }
      $picture.css("left",left + "px");
      moving = false;
    });
  }

L'étape suivante est le bouton de navigation ci-dessous. Lorsque vous cliquez dessus, il passera automatiquement à l'image correspondante et le bouton cliqué sera également mis en surbrillance.

 /**
  * 这个函数是用于点亮下方的几个小按钮的
  */
  function activeBtn(){
    if(index < 1){
      index = 6;
    }    if(index > 6){
      index = 1;
    }    let $cur_active = $(".button-group").find(".active");    if($cur_active.attr("index") !== index){
      $cur_active.removeClass("active");
      $(".button-group").find(&#39;[index=&#39; + index+&#39;]&#39;).addClass("active");
    }
  }

La dernière étape consiste à écrire la fonction de carrousel automatique. Cette fonction doit exécuter régulièrement les deux fonctions ci-dessus

 /**
  * 实现焦点图自动轮播
  */
  function autoMove(){
    index += 1;
    activeBtn();
    move(-480);
    timeoutId = setTimeout(autoMove,5000);
  }

Ce qui suit est le code pour d'autres liaisons d'événements

let index = 1;//当前为第几张图片
  let timeoutId;  let moving = false;
  timeoutId = setTimeout(autoMove,5000);  //为左右翻页添加点击事件
  $("#left").click(function(event){
    event.preventDefault();    if(!moving){
      index -= 1;
      activeBtn();
      move(480);
    }
  });
  $("#right").click(function(event){
    event.preventDefault();    if(!moving){
      index += 1;
      activeBtn();
      move(-480);
    }
  });  //为下方按钮添加点击事件
  $(".button-group").click(function(event){
    let $target = $(event.target);    if($target.is("span")){      if(!moving){        let cur_index = parseInt($(this).find(".active").attr("index"));
        index = parseInt($target.attr("index"));
        activeBtn();
        move(-480 * (index - cur_index));
      }
    }
  });
  $(".focus").mouseenter(function(event){
    $(".arrow").css("visibility","visible");
    clearTimeout(timeoutId);//取消自动轮播
  })
  .mouseleave(function(event){
    $(".arrow").css("visibility","hidden");
    timeoutId = setTimeout(autoMove,5000);//重新设置自动轮播
  });
Résumé

Certaines choses nécessitent une attention particulière :

1. Après avoir déplacé l'image, vous devez déterminer si la valeur de gauche dépasse la valeur attendue, et la réinitialiser après avoir dépassé la valeur

2. Passez .attr("index ") La valeur d'index obtenue est une chaîne, qui doit être convertie en un entier, sinon une erreur se produira en cliquant sur le bouton de navigation ci-dessous
3. Lorsque l'image bouge, définissez passer à true afin que les autres boutons ne puissent pas être cliqués. Réinitialiser à false une fois le déplacement terminé

.

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!

Déclaration:
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