>  기사  >  웹 프론트엔드  >  jquery는 PC에서 캐러셀 이미지 코드를 구현합니다.

jquery는 PC에서 캐러셀 이미지 코드를 구현합니다.

小云云
小云云원래의
2018-01-31 10:15:182927검색

저는 최근 다른 프로젝트로 별로 바쁘지 않았습니다. 회사의 공식 웹사이트 프로젝트를 위한 새 페이지를 만드는 일을 맡았습니다. 프로젝트에서는 이미 jQuery를 사용했기 때문에 그냥 jQuery를 사용하여 캐러셀 이미지를 작성하겠습니다. 이 글에서는 주로 jquery를 사용하여 PC측 캐러셀 효과의 예제를 작성하는 방법을 설명합니다. 관심 있는 친구들은 참고할 수 있습니다.

이제 따로 작성한 캐러셀 이미지 코드를 꺼내서 작은 데모를 만들고 여기에 적어서 기록해두세요. (데모 속 캐러셀 이미지 사진은 온라인에서 무작위로 찾은 것입니다.)

얻은 효과:

1. 자동 캐러셀(캐러셀 시간 간격은 js 코드로 맞춤 설정됨)

2. 왼쪽 및 오른쪽 버튼을 클릭하면 수동 전환이 가능합니다.

3. 하단의 작은 점은 전환된 이미지의 위치에 따라 활성 상태를 표시합니다.

4 , 마우스가 캐러셀 영역을 통과하여 캐러셀을 중지하고 캐러셀 영역을 떠나 캐러셀을 시작합니다.

코드 디렉토리 결과는 다음과 같습니다.

1. index.html

Note : 여기 5장의 사진이 있습니다. 예를 들어, 페이지의 실제 캐러셀은 사용자에게 5개의 다른 그림을 보여줍니다. 그러나 캐러셀 효과의 연속성을 위해 첫 번째 그림 이전과 다섯 번째 그림 뒤에 다섯 번째 그림이 추가됩니다. 첫 번째 사진이 업로드되었으므로 데모 구조에는 7장의 사진이 있으며, 각 사진의 크기는 동일해야 합니다(여기서는 너비와 높이가 720*350px입니다).


<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>PC-jquery版轮播图</title>
 <link rel="stylesheet" href="css/style.css" rel="external nofollow" >
</head>
<body>
<p class="layout">
 <h2 style="text-align: center;">PC-jquery版轮播图</h2>
 <p class="slide" id="slide">
  <p id="outer" class="outer">
   <ul id="inner" class="inner">
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-5</p><img src="images/slide-5.jpg"></a></li>
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-1</p><img src="images/slide-1.jpg"></a></li>
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-2</p><img src="images/slide-2.jpg"></a></li>
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-3</p><img src="images/slide-3.jpg"></a></li>
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-4</p><img src="images/slide-4.jpg"></a></li>
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-5</p><img src="images/slide-5.jpg"></a></li>
    <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>图片-1</p><img src="images/slide-1.jpg"></a></li>
   </ul>       <!--底部小圆点-->
   <ol class="dot" id="dot">
    <li class="active"></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
   </ol>
  </p>
     <!--左右两侧的点击切换按钮-->
  <p class="arrow-box">
   <p class="arrow arrow-l" id="arrow_l">‹</p>
   <p class="arrow arrow-r" id="arrow_r">›</p>
  </p>
 </p>
</p>
<script src="js/jquery.min.js"></script>
<script src="js/index.js"></script>
</body>
</html>

2.style.css


* {
 margin: 0;
 padding: 0;
 box-sizing: border-box;
}
.layout {
 width: 1000px;
 margin: 30px auto;
}
ul,ol,li {
 list-style: none;
}
.slide {
 position: relative;
 width: 900px;
 margin:auto;
}
.slide .outer {
 position: relative;
 margin: 30px auto;
 width: 720px;
 height: 400px;
 overflow: hidden;
}
.slide .outer .inner {
 width: 5040px;
 height: 350px;
 position: absolute;
 left: -720px;
 top: 0;
}
.slide .outer .inner li {
 float: left;
 height: 350px;
}
.slide .outer .inner li a {
 display: block;
 position: relative;
 width: 100%;
 height: 100%;
}
.slide .outer .inner li a p {
 position: absolute;
 left: 0;
 bottom: 0;
 color: #fff;
 font-size: 18px;
 width: 720px;
 height: 80px;
 line-height: 80px;
 padding-left: 50px;
 background: linear-gradient(180deg,rgba(0,0,0,0), rgba(0,0,0,0.5));
}
.slide .outer .dot {
 margin-top: 365px;
 text-align: center;
}
.slide .outer .dot li {
 height: 6px;
 width: 6px;
 border-radius: 3px;
 background-color: #d2cbcb;
 display: inline-block;
 margin: 0 3px;
}
.slide .outer .dot li.active {
 background-color: #6e5ca5;
}
.slide .arrow-box {
 position: absolute;
 width: 900px;
 height: 60px;
 top: 150px;
 left: 0;
}
.slide .arrow-box .arrow {
 width: 60px;
 height: 60px;
 line-height: 60px;
 text-align: center;
 border-radius: 30px;
 background-color: #dde2e6;
 font-size: 60px;
 color: #999;
 cursor: pointer;
}
.slide .arrow-box .arrow.arrow-l {
 float: left;
}
.slide .arrow-box .arrow.arrow-r {
 float: right;
}

3.index.js

참고: js 코드에는 각 변수가 주석 처리되어 있습니다. 여기서는 빠른 다중 클릭으로 인해 애니메이션이 정지되는 것을 방지하기 위해 이미지가 전환될 때마다 여기서 stop(false,true)를 호출합니다. 단, 왼쪽으로 스크롤할 때 마지막 사진으로 스크롤한 후 다시 전환할 때 stop(false,true) 을 사용하지 말고 즉시 첫 번째 사진(실제로는 dom 구조에서 세 번째 사진)(두 개의 사진)을 찾으세요. ) 마찬가지로 오른쪽으로 스크롤하면 첫 번째 사진으로 스크롤한 후 다시 전환할 때 중지(false, true)할 필요가 없지만 즉시 마지막 사진을 찾습니다(실제로는 두 번째에서 마지막 사진까지의 돔 구조). ).


var interval = 3000;    //轮播间隔时间
var arrowL = $(&#39;#arrow_l&#39;);   //左侧箭头
var arrowR = $(&#39;#arrow_r&#39;);   //右侧箭头

var slideBox = $(&#39;#slide&#39;);   //轮播图区域
var innerBox = $(&#39;#inner&#39;);   //内层大盒子
var img = innerBox.children(&#39;li&#39;); //每个图片
var dot = $(&#39;#dot&#39;);    //小圆点盒子

var imgW = $(img[0]).outerWidth(); //每个li标签的宽度

var imgCount = 5;     //总图片个数(不同图片的个数)(实际dom上是有7张)
var i = 0;       //初始化为第0张图片
timer = null;      //定时器

//自动轮播
timer = setInterval(function () {
 i++;
 innerBox.stop(false, true).animate({&#39;left&#39;:-i*imgW+&#39;px&#39;},300)
 dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(i-1).addClass(&#39;active&#39;)
 if(i > imgCount){
  innerBox.animate({&#39;left&#39;:-1*imgW+&#39;px&#39;},0);
  dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(0).addClass(&#39;active&#39;)
  i = 1;
 }
},interval)

//点击右侧箭头,播放下一张
arrowR.click(function () {
 i++;
 innerBox.stop(false, true).animate({&#39;left&#39;:-i*imgW+&#39;px&#39;},300)
 dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(i-1).addClass(&#39;active&#39;)
 if(i > imgCount){
  innerBox.animate({&#39;left&#39;:-1*imgW+&#39;px&#39;},0);
  dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(0).addClass(&#39;active&#39;)
  i = 1;
 }
})

//点击左侧箭头,播放上一张
arrowL.click(function () {
 i--;
 innerBox.stop(false, true).animate({&#39;left&#39;:-i*imgW+&#39;px&#39;},300)
 dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(i-1).addClass(&#39;active&#39;)
 if(i < 1){
  innerBox.animate({&#39;left&#39;:-imgCount*imgW+&#39;px&#39;},0);
  dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(imgCount-1).addClass(&#39;active&#39;)
  i = imgCount;
 }
})
//鼠标经过轮播图区域时,清除定时器,停止自动轮播
slideBox.mouseenter(function () {
 clearInterval(timer);
})

//鼠标离开轮播图区域时,重新启动自动轮播
slideBox.mouseleave(function () {
 timer = setInterval(function () {
  i++;
  innerBox.stop(false, true).animate({&#39;left&#39;:-i*imgW+&#39;px&#39;},300)
  dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(i-1).addClass(&#39;active&#39;)
  if(i > imgCount){
   innerBox.animate({&#39;left&#39;:-1*imgW+&#39;px&#39;},0);
   dot.find(&#39;li&#39;).removeClass(&#39;active&#39;).eq(0).addClass(&#39;active&#39;)
   i = 1;
  }
 },interval)
})

관련 권장사항:

회전형 차트를 구현하는 두 가지 js 방법

캡슐화된 모션 프레임워크의 실제 구현에서 슬라이딩 포커스 회전형 차트에 대한 설명

회전형 차트 효과의 jquery 버전 및 확장 확장 인스턴스 공유


위 내용은 jquery는 PC에서 캐러셀 이미지 코드를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.