国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JS實現的相冊圖片左右滾動完整實例

2019-11-19 18:50:50
字體:
來源:轉載
供稿:網友

本文實例講述了JS實現的相冊圖片左右滾動效果。分享給大家供大家參考,具體如下:

執行左移右移函數:

var $get = function(id) {  return "string" == typeof id ? document.getElementById(id) : id;};var Extend = function(destination, source) {  for (var property in source) {    destination[property] = source[property];  }  return destination;}var CurrentStyle = function(element) {  return element.currentStyle || document.defaultView.getComputedStyle(element, null);}var Bind = function(object, fun) {  var args = Array.prototype.slice.call(arguments).slice(2);  return function() {    return fun.apply(object, args.concat(Array.prototype.slice.call(arguments)));  }}var Tween = {  Quart: {    easeOut: function(t, b, c, d) {      return -c * ((t = t / d - 1) * t * t * t - 1) + b;    }  },  Back: {    easeOut: function(t, b, c, d, s) {      if (s == undefined) s = 1.70158;      return c * ((t = t / d - 1) * t * ((s + 1) * t + s) + 1) + b;    }  },  Bounce: {    easeOut: function(t, b, c, d) {      if ((t /= d) < (1 / 2.75)) {        return c * (7.5625 * t * t) + b;      } else if (t < (2 / 2.75)) {        return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;      } else if (t < (2.5 / 2.75)) {        return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;      } else {        return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;      }    }  }}//容器對象,滑動對象,切換數量var SlideTrans = function(container, slider, count, options) {  this._slider = $get(slider);  this._container = $get(container); //容器對象  this._timer = null; //定時器  this._count = Math.abs(count); //切換數量  this._target = 0; //目標值  this._t = this._b = this._c = 0; //tween參數  this.Index = 0; //當前索引  this.SetOptions(options);  this.Auto = !!this.options.Auto;  this.Duration = Math.abs(this.options.Duration);  this.Time = Math.abs(this.options.Time);  this.Pause = Math.abs(this.options.Pause);  this.Tween = this.options.Tween;  this.onStart = this.options.onStart;  this.onFinish = this.options.onFinish;  var bVertical = !!this.options.Vertical;  this._css = bVertical ? "top" : "left"; //方向  //樣式設置  var p = CurrentStyle(this._container).position;  p == "relative" || p == "absolute" || (this._container.style.position = "relative");  this._container.style.overflow = "hidden";  this._slider.style.position = "absolute";  this.Change = this.options.Change ? this.options.Change :    this._slider[bVertical ? "offsetHeight" : "offsetWidth"] / this._count;};SlideTrans.prototype = {  //設置默認屬性  SetOptions: function(options) {    this.options = {//默認值    Vertical: true, //是否垂直方向(方向不能改)      Auto: false, //是否自動      Change: 0, //改變量      Duration: 50, //滑動持續時間      Time: 10, //滑動延時      Pause: 2000, //停頓時間(Auto為true時有效)      onStart: function() { }, //開始轉換時執行      onFinish: function() { }, //完成轉換時執行      Tween: Tween.Quart.easeOut//tween算子    };    Extend(this.options, options || {});  },  //開始切換  Run: function(index) {    //修正index    index == undefined && (index = this.Index);    index < 0 && (index = this._count - 1) || index >= this._count && (index = 0);    //設置參數    this._target = -Math.abs(this.Change) * (this.Index = index);    this._t = 0;    this._b = parseInt(CurrentStyle(this._slider)[this.options.Vertical ? "top" : "left"]);    this._c = this._target - this._b;    this.onStart();    this.Move();  },  //移動  Move: function() {    clearTimeout(this._timer);    //未到達目標繼續移動否則進行下一次滑動    if (this._c && this._t < this.Duration) {      this.MoveTo(Math.round(this.Tween(this._t++, this._b, this._c, this.Duration)));      this._timer = setTimeout(Bind(this, this.Move), this.Time);    } else {      this.MoveTo(this._target);      this.Auto && (this._timer = setTimeout(Bind(this, this.Next), this.Pause));    }  },  //移動到  MoveTo: function(i) {    this._slider.style[this._css] = i + "px";  },  //下一個  Next: function() {    this.Run(++this.Index);  },  //上一個  Previous: function() {    this.Run(--this.Index);  },  //停止  Stop: function() {    clearTimeout(this._timer); this.MoveTo(this._target);  }};

在前天html加入div容器:

<!-- Icon scroll begin --><div style="text-align:center; width:100%; margin:auto auto">  <div class="container" id="idContainer" runat="server" >  </div></div><!--end--><!--左右滾動按鈕--><div class="defaultprenext"><table cellpadding=0 cellspacing=0 style="width:100%"> <tr>   <td style="width:40%; text-align:left; padding-left:6px">   <img id="ImgPre" alt="" src="ImageV3/Default/pre-gray.png" />   <span class="pager" id="Pre" style="color:Gray">Pre</span></td>   <td style="width:20%; text-align:center">     <div class="defaultprenextmid">      <div style="height:10px; vertical-align:middle; line-height:10px">       <img src="ImageV3/Default/greendot.png" id="Img1" />         <img src="ImageV3/Default/graydot.png" id="Img2" />         <img src="ImageV3/Default/graydot.png" id="Img3" />      </div>    </div>   </td>   <td style="width:40%; text-align:right; padding-right:6px">    <span class="pager" id="Next" style="color:#2f6417">Next</span>    <img id="ImgNext" alt="" src="ImageV3/Default/next-green.png" />   </td> </tr></table></div>

下面是改變左右按鈕可用狀態

var imgNum = $get("idContainer").getElementsByTagName("img").length;var pre = $get("Pre");var next = $get("Next");var i = 0;if (imgNum > 0) {  var st = new SlideTrans("idContainer", "idSlider", 3, { Vertical: false });  if (i < 2) {    $get("Next").onclick = function() {      if (i < 2) {        st.Next();        i++;        if (i == 1) {          $get("ImgPre").src = "ImageV3/Default/pre-green.png";          pre.style.color = "#2f6417";        }        if (i == 2) {          $get("ImgNext").src = "ImageV3/Default/next-gray.png";          next.style.color = "Gray";        }        ChangePicIndex(i);      }    }  }  $get("Pre").onclick = function() {    if (i > 0) {      st.Previous();      $get("ImgNext").src = "ImageV3/Default/next-green.png";      next.style.color = "#2f6417";      i--;      if (i == 0) {        $get("ImgPre").src = "ImageV3/Default/pre-gray.png";        pre.style.color = "Gray";      }      ChangePicIndex(i);    }  }  st.Run();}function ChangePicIndex(index) {  switch (index) {    case 1:      $get("Img1").src = "ImageV3/Default/graydot.png";      $get("Img2").src = "ImageV3/Default/greendot.png";      $get("Img3").src = "ImageV3/Default/graydot.png";      break    case 2:      $get("Img1").src = "ImageV3/Default/graydot.png";      $get("Img2").src = "ImageV3/Default/graydot.png";      $get("Img3").src = "ImageV3/Default/greendot.png";      break    default:      $get("Img1").src = "ImageV3/Default/greendot.png";      $get("Img2").src = "ImageV3/Default/graydot.png";      $get("Img3").src = "ImageV3/Default/graydot.png";  }}

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 凭祥市| 遂宁市| 乐昌市| 东阿县| 荥经县| 临高县| 东港市| 阿鲁科尔沁旗| 隆安县| 石家庄市| 保山市| 乌兰县| 沙田区| 泽普县| 鲁山县| 梨树县| 陵水| 且末县| 普安县| 呼玛县| 澄城县| 锦州市| 金门县| 仁布县| 绥中县| 上虞市| 广南县| 策勒县| 浮山县| 泊头市| 石首市| 永泰县| 玉环县| 米脂县| 从化市| 内乡县| 大悟县| 高要市| 潮安县| 无棣县| 长丰县|