亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

靈活使用數(shù)組制作圖片切換js實(shí)現(xiàn)

 更新時(shí)間:2016年07月28日 17:22:21   作者:macanfa  
這篇文章主要介紹了靈活使用數(shù)組制作圖片切換效果,js實(shí)現(xiàn)圖片切換特效,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

js活用數(shù)組制作圖片切換效果,供大家參考,具體內(nèi)容如下

數(shù)組元素位置變換:

將內(nèi)容分割為數(shù)組,將第一個(gè)加到最后,刪掉第一個(gè)

<div id="box">1,2,3,4</div>
<input type="button" value='切換' id='input'>
<script>
 window.onload=function(){
 var oDiv=document.getElementById('box');
 var oInput=document.getElementById('input');

 oInput.onclick=function(){
  var arr=oDiv.innerHTML.split(',');
  // console.log(arr);
  arr.push(arr[0]);//將第一個(gè)加到最后,刪掉第一個(gè)
  arr.shift();
  oDiv.innerHTML=arr;
 }
 }
</script>

模擬圖片切換效果:

window.onload=function(){
 var aDiv=document.getElementsByTagName('div');
 var aInput=document.getElementsByTagName('input');
 var arr=[];//創(chuàng)建空數(shù)組用于存放屬性

 for(var i=0;i<aDiv.length;i++){
 console.dir(getStyle(aDiv[i],'left'));//獲取到純凈的最終樣式
 //將屬性作為 符合數(shù)組 加入arr中,可用于多屬性
   arr.push([getStyle(aDiv[i],'left'),getStyle(aDiv[i],'top')]);
 }
 // console.dir(arr);

 aInput[0].onclick=function(){//將第一個(gè)加到最后,刪掉第一個(gè)
 arr.push(arr[0]);
 arr.shift();
 for(var i=0;i<aDiv.length;i++){//操作完數(shù)組后重新賦值
  aDiv[i].style.left=arr[i][0];
  aDiv[i].style.top=arr[i][1];
 }
 };
 aInput[1].onclick=function(){//將最后一個(gè)加到最前,刪最后
 arr.unshift(arr[arr.length-1]);
 arr.pop();
 for(var i=0;i<aDiv.length;i++){
  aDiv[i].style.left=arr[i][0];
  aDiv[i].style.top=arr[i][1];
 }
 };
 function getStyle(obj,attr){//獲取最終樣式
 if(obj.currentStyle){
  return obj.currentStyle[attr];
 }else{
  return getComputedStyle(obj,false)[attr];
 }
 }
}

簡(jiǎn)陋效果圖:

數(shù)組元素位置切換

實(shí)例版:

思路:
若有五張圖片:圖1~5的left值分別為:20px、60px、100px、240px、380px;
點(diǎn)擊左切換按鈕后,對(duì)應(yīng)的圖1~5left值變?yōu)椋?0px、100px、240px、380px、20px;

--------------------------------------------------------------------------------

相當(dāng)于這組數(shù)組第一個(gè)元素移到最后:20px、60px、100px、240px、380px、20px;
然后再把第一個(gè)元素刪除得:60px、100px、240px、380px、20px;
以此類推:

實(shí)例布局:

<div id="box">
 <ul>
 <li class='pos_0'><img src="images/1.png" width='300'></li>
 <li class='pos_1'><img src="images/1.jpg" width='400'></li>
 <li class='pos_2'><img src="images/2.jpg" width='500'></li>
 <li class='pos_3'><img src="images/3.jpg" width='400'></li>
 <li class='pos_4'><img src="images/1.jpg" width='300'></li>
 </ul>
 <span class='dir dirl'></span>
 <span class='dir dirr'></span>
</div>

實(shí)例樣式:

#box{width:700px;height:300px;position:relative;margin:20px auto;text-align: center;}
#box ul{list-style: none;}
#box ul li{position:absolute;}
#box ul li.pos_0{top:50px;left:20px;z-index:1;opacity:0.5;}
#box ul li.pos_1{top:20px;left:60px;z-index:2;opacity:0.8;}
#box ul li.pos_2{top:0px;left:100px;z-index:3;opacity:1;}
#box ul li.pos_3{top:20px;left:240px;z-index:2;opacity:0.8;}
#box ul li.pos_4{top:50px;left:380px;z-index:1;opacity:0.5;}
.dir{display: inline-block;width:45px;height:100px;background:url('images/button.png') no-repeat;
position:absolute;top:60px;z-index:4;}
.dirl{background-position: 0px 0;left:40px;}
.dirr{background-position: -55px 0;right:40px;}

JS代碼:

window.onload=function(){
 var oPre=document.getElementsByClassName('dir')[0];
 var oNext=document.getElementsByClassName('dir')[1];
 var aLi=document.getElementsByTagName('li');
 var arr=[];
 for(var i=0;i<aLi.length;i++){
 var oImg=aLi[i].getElementsByTagName('img')[0];
 // console.log(getStyle(aLi[i],'left'));
 // console.log(parseInt(getStyle(aLi[i],'opacity')*100));
 // console.log(getStyle(aLi[i],'z-index'));
 // console.log(oImg.width);
 arr.push([
  parseInt(getStyle(aLi[i],'top')),
  parseInt(getStyle(aLi[i],'opacity')*100),
  parseInt(getStyle(aLi[i],'z-index')),
  oImg.width
  ]);
 // console.log(arr[i][2]);
 }
 // console.dir(arr);
 oPre.onclick=function(){//左
 arr.push(arr[0]);
 arr.shift();
 for(var i=0;i<aLi.length;i++){

  var oImg=aLi[i].getElementsByTagName('img')[0];
  //console.log(arr[i][2]);
  startMove(aLi[i],{
  left:arr[i][0],
  top:arr[i][1],
  opacity:arr[i][2],
  });
  aLi[i].style.zIndex=arr[i][3];
  startMove(oImg,{width:arr[i][4]});
 }
 };
 oNext.onclick=function(){//右
 arr.unshift(arr[arr.length-1]);
 arr.pop();
 for(var i=0;i<aLi.length;i++){

  var oImg=aLi[i].getElementsByTagName('img')[0];

  startMove(aLi[i],{
  left:arr[i][0],
  top:arr[i][1],
  opacity:arr[i][2],
  });

  aLi[i].style.zIndex=arr[i][3];
  startMove(oImg,{width:arr[i][4]});
 }
 };
 function getStyle(obj,attr){//得到是帶單位的數(shù)值
 if(obj.currentStyle){
  return obj.currentStyle[attr];
 }else{
  return getComputedStyle(obj,false)[attr];
 }
 }
}

效果圖:

js圖片切換效果

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

相關(guān)文章

  • webpack文件打包錯(cuò)誤異常

    webpack文件打包錯(cuò)誤異常

    這篇文章主要介紹了webpack文件打包錯(cuò)誤異常,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 20行JS代碼實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果

    20行JS代碼實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果

    下面小編就為大家?guī)?lái)一篇20行JS代碼實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06
  • 惰性函數(shù)定義模式 使用方法

    惰性函數(shù)定義模式 使用方法

    惰性函數(shù)定義模式 使用方法...
    2007-09-09
  • vue2.0實(shí)戰(zhàn)之基礎(chǔ)入門(1)

    vue2.0實(shí)戰(zhàn)之基礎(chǔ)入門(1)

    這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)戰(zhàn)第一篇基礎(chǔ)入門的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • js實(shí)現(xiàn)數(shù)組冒泡排序、快速排序原理

    js實(shí)現(xiàn)數(shù)組冒泡排序、快速排序原理

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)數(shù)組冒泡排序、快速排序的原理,感興趣的小伙伴們可以參考一下
    2016-03-03
  • js實(shí)現(xiàn)購(gòu)物車計(jì)算的方法

    js實(shí)現(xiàn)購(gòu)物車計(jì)算的方法

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)購(gòu)物車的計(jì)算方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 如何在JavaScript中創(chuàng)建具有多個(gè)空格的字符串?

    如何在JavaScript中創(chuàng)建具有多個(gè)空格的字符串?

    這篇文章主要介紹了如何在JavaScript中創(chuàng)建具有多個(gè)空格的字符串?,需要的朋友可以參考下
    2020-02-02
  • JavaScript 模塊的循環(huán)加載實(shí)現(xiàn)方法

    JavaScript 模塊的循環(huán)加載實(shí)現(xiàn)方法

    本文介紹JavaScript語(yǔ)言如何處理"循環(huán)加載"。目前,最常見(jiàn)的兩種模塊格式CommonJS和ES6,處理方法是不一樣的,返回的結(jié)果也不一樣
    2015-12-12
  • 深入詳解JS函數(shù)的柯里化

    深入詳解JS函數(shù)的柯里化

    JavaScript作為一種弱類型語(yǔ)言,它的隱式轉(zhuǎn)換是非常靈活有趣的。當(dāng)我們沒(méi)有深入了解隱式轉(zhuǎn)換的時(shí)候可能會(huì)對(duì)一些運(yùn)算的結(jié)果會(huì)感動(dòng)困惑,比如4 + true = 5。當(dāng)然,如果對(duì)隱式轉(zhuǎn)換了解足夠深刻,能夠提高對(duì)js的使用能力。這里分享一下,函數(shù)在隱式轉(zhuǎn)換中的一些規(guī)則
    2021-06-06
  • JavaScript實(shí)現(xiàn)的select點(diǎn)菜功能示例

    JavaScript實(shí)現(xiàn)的select點(diǎn)菜功能示例

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)的select點(diǎn)菜功能,涉及javascript動(dòng)態(tài)操作頁(yè)面元素及元素遍歷相關(guān)技巧,需要的朋友可以參考下
    2017-01-01

最新評(píng)論