欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實現(xiàn)圖片輪播特效

 更新時間:2019年10月23日 10:06:35   作者:qq_29750461  
這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)圖片輪播特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

今天給大家介紹下怎么用 JS 實現(xiàn)圖片輪播效果。

原理描述:

使用JS實現(xiàn)輪播的原理是這樣的:

假設(shè)初始的情況,下圖一個網(wǎng)格代表一個圖,初始時,顯示1 :

當(dāng)進(jìn)行一次輪播后,顯示變?yōu)橄聢D 顯示2:

依次類推。

代碼實現(xiàn):

1 JS 代碼:

<script type="text/javascript">
 window.οnlοad=function(){
 //獲得ul的元素
 var imgList=document.getElementById("imgList");
 //獲得圖片的數(shù)組
 var imgArr=document.getElementsByTagName("img");
 var navId=document.getElementById("navId");
 var outer=document.getElementById("outer");
 imgList.style.width=520*imgArr.length+"px";
 //設(shè)置navId的位置 使其居中
 navId.style.left=(outer.offsetWidth-navId.offsetWidth)/2+"px";
 //得到所有的a 標(biāo)簽 如果有其他的A的話 這里需要注意要使用navId子元素的a 
 var allA=document.getElementsByTagName("a");
 var index=0;
 allA[index].style.backgroundColor='black';//設(shè)置默認(rèn)的a為黑色
 for(var i=0;i<allA.length;i++){
  allA[i].num=i;
  //alert(allA[i].num);
  allA[i].οnclick=function(){
  clearInterval(timer);
  index=this.num;
  /* imgList.style.left= -520*index+"px"; */
  setA();
  move(imgList,"left",-520*index,50,function(){
   autoChange();
  });
  };
 }
 
 function setA(){
  //alert(index);
  //當(dāng)indcx值比圖片的數(shù)目多的時候 就歸0
  if(index>=imgArr.length-1){
  index=0;
  imgList.style.left=0;
  } 
  for(var i=0;i<allA.length;i++){
  //去掉未點擊的顏色 仍然保留a : hover有用
  allA[i].style.backgroundColor="";
  }
  allA[index].style.backgroundColor="black";
 }
 var timer;
 function autoChange(){
  
  timer=setInterval(function(){
  index++;
  index%=imgArr.length;
  move(imgList,"left",-520*index,20,function(){
   setA();
   });
  },2000); 
 }
 autoChange();

//可以根據(jù) target 參數(shù)進(jìn)行判斷 向哪個方向移動
 function move(obj,attr,target,speed,callback){
  var current=parseInt(getStyle(obj,attr));
  //alert(current);
  //根據(jù)目標(biāo)的位置來判定 speed的值是正是負(fù)
  if(current>target){
  speed=-speed;
  }
  //自定義對象定時器 防止對象之間的混亂操作 
  clearInterval(obj.timer);
  //alert(oldValue);
  obj.timer=setInterval(function(){
  var oldValue=parseInt(getStyle(obj,attr));
  var newVal=oldValue+speed;
  //如果移動的越界 進(jìn)行重置
  if((speed<0 && newVal<=target) || (speed>0 && newVal>=target)){
   newVal=target;
  }
  obj.style[attr]=newVal+"px";
  if(newVal==target){
   clearInterval(obj.timer);
   callback && callback();//回掉函數(shù) 先判斷 有就執(zhí)行 沒有不執(zhí)行
  } 
  },30);
 }
 
 //obj:獲取樣式元素
 //name:獲取樣式名
 function getStyle(obj,name){
  if(window.getComputedStyle){
  return getComputedStyle(obj,null)[name];
  }else{
  return obj.currentStyle[name];
  }
 }
 }
</script>

2  HTML 代碼:

<div id="outer">
 <ul id="imgList">
 <li><img src="img/1.jpg"></li>
 <li><img src="img/2.jpg"></li>
 <li><img src="img/3.jpg"></li>
 <li><img src="img/1.jpg"></li><!-- 增加這個為了實現(xiàn)輪播無縫切換 -->
 </ul>
 <div id="navId">
 <a href="javascript:0" ></a>
 <a href="javascript:0" ></a>
 <a href="javascript:0" ></a>

 </div>
</div>

3 CSS代碼:

<style type="text/css">
 *{
 margin:0px;
 padding:0px;
 }
 #outer{
 width:520px;
 height:500px;
 margin:50px auto;
 background-color:greenyellow;
 padding:10px 0;
 /* 開啟相對定位*/ 
 position:relative;
 overflow:hidden;/* 將超出的部分隱藏 */
 /* border:3px solid greenyellow */
 }
 #imgList{
 /*去除li的點*/
 list-style:none;
 /*開啟絕對定位 */
 position:absolute;
 /*設(shè)置ul的寬度*/
 /* width:1560px; */
 }
 #imgList li{
 /*為圖片設(shè)置浮動*/
 float:left;
 margin:0 10px;/*設(shè)置左右外邊距*/
 }
 #navId{
 /* 開啟絕對定位 */
 position:absolute;
 /*設(shè)置位置*/
 bottom:15px;
 /*設(shè)置該塊的左偏移量,使其可以居中
 由于outer 寬 520 每個鏈接寬15+2*5=25 目前共三張圖,則共寬75*/
 /* left:212px; */
 }
 #navId a{
 width:15px;
 height:15px;
 float:left;/* 設(shè)置超鏈接浮動 */
 margin:0 5px;
 background-color:red;
 opacity:0.5;
 /*兼容 IE8 設(shè)置透明度*/
 filter:alpha(opacity=50);
 }
 /*設(shè)置鼠標(biāo)移入效果*/
 #navId a:hover{
 background-color:black;
 }
 
</style>

4 實現(xiàn)效果:

更多關(guān)于輪播圖效果的專題,請點擊下方鏈接查看學(xué)習(xí)

javascript圖片輪播效果匯總

jquery圖片輪播效果匯總

Bootstrap輪播特效匯總

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • HTML+CSS+JS實現(xiàn)的簡單應(yīng)用小案例分享

    HTML+CSS+JS實現(xiàn)的簡單應(yīng)用小案例分享

    這篇文章主要為大家分享四個用HTML+CSS+JS實現(xiàn)的簡單應(yīng)用小案例,有:猜數(shù)字、表白墻、切換日夜間模式和待辦事項,需要的可以參考一下
    2022-02-02
  • 微信小程序圖片右邊加兩行文字的代碼

    微信小程序圖片右邊加兩行文字的代碼

    這篇文章主要介紹了微信小程序圖片右邊加兩行文字的代碼,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • JS實現(xiàn)slide文字框縮放伸展效果代碼

    JS實現(xiàn)slide文字框縮放伸展效果代碼

    這篇文章主要介紹了JS實現(xiàn)slide文字框縮放伸展效果代碼,涉及JavaScript響應(yīng)鼠標(biāo)事件動態(tài)操作頁面元素屬性的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • javaScript中push函數(shù)用法實例分析

    javaScript中push函數(shù)用法實例分析

    這篇文章主要介紹了javaScript中push函數(shù)用法,較為詳細(xì)的分析了javascript中push函數(shù)的功能、定義及使用技巧,需要的朋友可以參考下
    2015-06-06
  • javascript消除window.close()的提示窗口

    javascript消除window.close()的提示窗口

    有人問起,怎么去掉js調(diào)用window.close()時怎么去掉那可惡的提示,咋一看好像還真不好弄,IE的安全機(jī)制好像就不允許通過腳本關(guān)閉本頁面,但是IE好像可以允許js關(guān)閉彈出窗口,那我們是不是可以通過一定的技巧欺騙一下IE,繞過去呢。鼓搗了幾下,似乎還真可以做到
    2015-05-05
  • js 實現(xiàn)碰撞檢測的示例

    js 實現(xiàn)碰撞檢測的示例

    這篇文章主要介紹了js 實現(xiàn)碰撞檢測的示例,幫助大家更好的制作js特效,美化自身網(wǎng)頁,感興趣的朋友可以了解下
    2020-10-10
  • 探討JavaScript語句的執(zhí)行過程

    探討JavaScript語句的執(zhí)行過程

    本文給大家介紹JavaScript語句的執(zhí)行過程的相關(guān)知識,對js語句執(zhí)行過程的相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • 談?wù)凧avaScript中function多重理解

    談?wù)凧avaScript中function多重理解

    Function是javascript里最常用的一個概念,javascript里的function是最容易入手的一個功能,但它也是javascript最難理解最難掌握的一個概念,接下來通過本篇文章給大家介紹javascript中的function多重理解,小伙伴們一起來學(xué)習(xí)吧
    2015-08-08
  • 基于JavaScript實現(xiàn)的插入排序算法分析

    基于JavaScript實現(xiàn)的插入排序算法分析

    這篇文章主要介紹了基于JavaScript實現(xiàn)的插入排序算法,結(jié)合實例形式詳細(xì)分析了插入排序的原理、操作步驟及javascript相關(guān)實現(xiàn)技巧與注意事項,需要的朋友可以參考下
    2017-04-04
  • JavaScript實現(xiàn)網(wǎng)頁動態(tài)生成表格

    JavaScript實現(xiàn)網(wǎng)頁動態(tài)生成表格

    這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)網(wǎng)頁動態(tài)生成表格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11

最新評論