Heim >Web-Frontend >js-Tutorial >jQuery klickt manuell, um Bildkarusselleffekte zu erzielen_jquery

jQuery klickt manuell, um Bildkarusselleffekte zu erzielen_jquery

WBOY
WBOYOriginal
2016-05-16 15:26:371334Durchsuche

In diesem Artikel habe ich ein Karussellbild geschrieben, um meine Fähigkeiten zu üben. Ich habe zuerst ein Karussellbild geschrieben, das manuell auf das Karussell klickt, und dann werde ich das automatische Karussellbild und das Mouseover-Bild langsam und tief schreiben, um die Bewegung zu stoppen das Karussellbild.
Werfen wir einen Blick auf den letzten manuellen Klickkarusselleffekt:

1. Prinzipielle Erklärung

(1) Das erste ist die Struktur des Karussellbilds. Ich verwende ein großes äußerstes Div, um zwei kleine Divs zu umschließen, und das andere kleine Div enthält vier Zahlenschaltflächen

(2) Stellen Sie die Breite des äußersten großen Divs auf die Breite des Bildes ein. Stellen Sie jedoch die Breite des kleinen Divs, das das Bild enthält, ein Eine größere Option erleichtert das Linksschweben der vier Bilder

(3) Wenn Sie auf die Zahlenschaltfläche klicken, ermitteln Sie den Indexwert der Schaltfläche, damit Sie wissen, um wie viel Breite jedes Bild nach links verschoben wird

Wie aus dem obigen Bild ersichtlich ist, sind die vier Bilder horizontal angeordnet. Wenn Sie auf die Nummernschaltfläche klicken, wird das Bild entsprechend dem Indexwert der Nummernschaltfläche angezeigt Bilder außerhalb des übergeordneten Rahmens werden ausgeblendet~~~~~Wenn Sie das Prinzip immer noch nicht verstehen, kann ich nur Blut erbrechen~~~~

2. Schauen wir uns das Hauptprogramm an

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8" />
  <title>轮播图①(手动点击轮播)</title>
  <link type="text/css" rel="stylesheet" href="css/layout.css" />
 </head>
 <body>
  <div class="slideShow">
   <!--图片布局开始-->
   <ul>
    <li><a href="#"><img src="img/picture01.jpg" /></a></li>
    <li><a href="#"><img src="img/picture02.jpg" /></a></li>
    <li><a href="#"><img src="img/picture03.jpg" /></a></li>
    <li><a href="#"><img src="img/picture04.jpg" /></a></li>
   </ul>
   <!--图片布局结束-->
   
   <!--按钮布局开始-->
   <div class="showNav">
    <span class="active">1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
   </div>
   <!--按钮布局结束-->
  </div>
  <script src="js/jquery-1.11.3.js"></script>
  <script src="js/layout.js"></script>
 </body>
</html>
Ich habe das obige Layout im Prinzip erklärt. Wenn Sie interessiert sind, können Sie das Prinzip selbst lesen~~~~

3. CSS-Stil

*{
 margin: 0;
 padding: 0;
}
ul{
 list-style: none;
}
.slideShow{
 width: 346px;
 height: 210px;  /*其实就是图片的高度*/
 border: 1px #eeeeee solid;
 margin: 100px auto;
 position: relative;
 overflow: hidden; /*此处需要将溢出框架的图片部分隐藏*/
}
.slideShow ul{
 width: 2000px;
 position: relative;  /*此处需注意relative : 对象不可层叠,但将依据left,right,top,bottom等属性在正常文档流中偏移位置,如果没有这个属性,图片将不可左右移动*/
}
.slideShow ul li{
 float: left;  /*让四张图片左浮动,形成并排的横着布局,方便点击按钮时的左移动*/
 width: 346px;
}
.slideShow .showNav{  /*用绝对定位给数字按钮进行布局*/
 position: absolute;
 right: 10px;
 bottom: 5px;
 text-align:center;
 font-size: 12px; 
 line-height: 20px;
}
.slideShow .showNav span{
 cursor: pointer;
 display: block;
 float: left;
 width: 20px;
 height: 20px;
 background: #ff5a28;
 margin-left: 2px;
 color: #fff;
}
.slideShow .showNav .active{
 background: #b63e1a;
}
Ich habe die wichtigen Punkte im obigen Stil notiert. Ich glaube, es ist leicht zu verstehen, wenn Sie über Grundkenntnisse verfügen. Zuerst habe ich vergessen, position: relative zu schreiben Nachfolgende JQuery-Programmbilder konnten nicht verschoben werden. Es hat lange gedauert, bis ich diesen Fehler gefunden habe. ~~~~~~~

4. jQuery-Programm

$(document).ready(function(){
 var slideShow=$(".slideShow"),  //获取最外层框架的名称
  ul=slideShow.find("ul"),  
  showNumber=slideShow.find(".showNav span"),//获取按钮
  oneWidth=slideShow.find("ul li").eq(0).width(); //获取每个图片的宽度
  
  showNumber.on("click",function(){   //为每个按钮绑定一个点击事件  
   $(this).addClass("active").siblings().removeClass("active"); //按钮被点击时为这个按钮添加高亮状态,并且将其他按钮高亮状态去掉
   var index=$(this).index(); //获取哪个按钮被点击,也就是找到被点击按钮的索引值
   ul.animate({
    "left":-oneWidth*index, //注意此处用到left属性,所以ul的样式里面需要设置position: relative; 让ul左移N个图片大小的宽度,N根据被点击的按钮索引值index确定
   })
  })
})
Glauben Sie, dass es sehr einfach ist, den Karusselleffekt durch manuelles Klicken in nur wenigen Worten zu erzielen? Was Sie im obigen Programm beachten müssen, ist, dass das linke Attribut nach links verschoben wird ist ein negativer Wert~~~~~~~

Ich werde die automatischen Karusselleffekte im nächsten Artikel mit Ihnen teilen, ich hoffe, Sie verpassen sie nicht.

Stellungnahme:
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