亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

使用原生js封裝webapp滑動效果(慣性滑動、滑動回彈)

2019-11-20 20:43:52
字體:
來源:轉載
供稿:網友

PC 移動端兼容  IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+ 慣性助動,滑動回彈

門面模式

復制代碼 代碼如下:

window.onload = function() {
 /*測試數據*/
 var insert = '';
 for (var i = 0; i < 80; i++) {
  insert += '<div style = "width:100%; text-align:center;">滑動測試 ' + i + '</div>';
 }
 document.getElementById("moveArea").innerHTML = insert;
 /*測試數據   */
 var at = new appTouch({
  tContain : 'appArea', //必選:滑動區域id
  tMove : 'moveArea', //必選:移動區域id
  tScroller : 'scroller', //必選:自定義滾動條
  tScrollerArea : 'scrollerArea'//必選:滾動條區域
 }, onmoveend);
 //到頂/底回調
 function onmoveend(m) {
  //console.log(m);
 }

}
/*=====================
 * 名稱: appTouch
 * 功能: web app滑動模擬組件
 * 參數: 相關配置
 ======================*/
var appTouch = function(config, callback) {
 this.touchContain = config.tContain;
 this.touchMove = config.tMove;
 this.touchScroller = config.tScroller;
 this.touchScrollerArea = config.tScrollerArea;
 this.callbackfn = callback;
 this.move();
}

appTouch.prototype = {
 move : function(e) {
  var monitor = document.getElementById(this.touchContain), //監聽容器
  target = document.getElementById(this.touchMove), //移動目標
  scroller = document.getElementById(this.touchScroller), //自定義滾動條
  scrollerArea = document.getElementById(this.touchScrollerArea), //滾動條區域
  sheight = monitor.offsetHeight / target.offsetHeight * monitor.offsetHeight, //自定義滾動條的長度
  st = (target.offsetHeight - monitor.offsetHeight) / (monitor.offsetHeight - sheight), //移動塊對應滾輪單位長度
  tslow = 4, //到頂/底減基數
  tMove = 0, //滑塊到頂top值
  tMoveL = tMove + 140, //到頂允許下拉范圍
  bMove = monitor.offsetHeight - target.offsetHeight, //滑塊到底top值
  bMoveL = bMove - 140, //到底允許上滑范圍
  callbackfn = this.callbackfn, //回調函數
  flg = false, //標記是否滑動
  startY, //標記起始位置
  startTop, //標記滑動起始時的高度值
  move = 0;
  //移動距離
  //鼠標事件注冊
  addEvent(monitor, 'mousedown', moveStart);
  addEvent(monitor, 'mousemove', moveIn);
  addEvent(monitor, 'mouseup', moveEnd);
  addEvent(window, 'mousemove', moveIn);
  addEvent(window, 'mouseup', moveEnd);
  //移動設備觸摸事件注冊
  addEvent(monitor, 'touchstart', moveStart);
  addEvent(monitor, 'touchmove', moveIn);
  addEvent(monitor, 'touchend', moveEnd);
  /**
   *外觀/門面模式包裝
   */
  /*事件監聽 */
  function addEvent(el, type, fn) {
   if (el.addEventListener) {
    el.addEventListener(type, fn, false);
   } else if (el.attachEvent) {
    el.attachEvent('on' + type, fn);
   } else {
    el['on' + type] = fn;
   }
  }

  //取消瀏覽器默認行為
  function stop(e) {
   //Opera/Chrome/FF
   if (e.preventDefault)
    e.preventDefault();
   //IE
   e.returnValue = false;
  }

  //包裝結束
  /**
   *操作函數
   */
  //慣性緩動參數
  var lastMoveTime = 0;
  var lastMoveStart = 0;
  var stopInertiaMove = false;
  /*移動觸發*/
  function moveStart(e) {
   stop(e);
   flg = true;
   if (e.touches)
    e = e.touches[0];
   startY = e.clientY;
   startTop = target.style.top || 0;
   //慣性緩動
   lastMoveStart = startY;
   lastMoveTime = new Date().getTime();
   stopInertiaMove = true;
   scrollerArea.style.visibility = 'visible';

  }

  /*移動過程中*/
  function moveIn(e) {
   if (flg) {
    stop(e);
    if (e.touches)
     e = e.touches[0];
    move = e.clientY - startY + parseInt(startTop);
    if (move > tMove) {
     (move - tMove) / tslow + tMove > tMoveL ? move = tMoveL : move = (move - tMove) / tslow + tMove

    } else if (move < bMove)
     (move - bMove) / tslow + bMove < bMoveL ? move = bMoveL : move = (move - bMove) / tslow + bMove;
    target.style.top = move + 'px';
    scroller.style.top = -move / st + 'px';
    //慣性緩動
    var nowTime = new Date().getTime();
    stopInertiaMove = true;
    if (nowTime - lastMoveTime > 300) {
     lastMoveTime = nowTime;
     lastMoveStart = e.clientY;
    }
   }
  }

  /*移動結束*/
  function moveEnd(e) {
   stop(e);
   if (e.touches)
    e = e.touches[0];
   //慣性緩動
   var contentTop = target.style.top.replace('px', '');
   var contentY = (parseInt(contentTop) + e.clientY - lastMoveStart);
   var nowTime = new Date().getTime();
   var v = (e.clientY - lastMoveStart) / (nowTime - lastMoveTime);
   //最后一段時間手指劃動速度
   stopInertiaMove = false;
   (function(v, startTime, contentY) {
    var dir = v > 0 ? -1 : 1;
    //加速度方向
    var deceleration = dir * 0.005;
    function inertiaMove() {
     if (stopInertiaMove)
      return;
     var nowTime = new Date().getTime();
     var t = nowTime - startTime;
     var nowV = v + t * deceleration;
     var moveY = (v + nowV) / 2 * t;
     // 速度方向變化表示速度達到0了
     if (dir * nowV > 0) {
      if (move > tMove) {
       callbackfn('到頂了');
       target.style.top = tMove + 'px';
       scroller.style.top = tMove + 'px';
      } else if (move < bMove) {
       callbackfn('到底了');
       target.style.top = bMove + 'px';
       scroller.style.top = -bMove / st + 'px';
      }
      setTimeout(function() {
       if (!stopInertiaMove)
        scrollerArea.style.visibility = 'hidden';
      }, 4000);
      return;
     }
     move = contentY + moveY;
     if (move > tMove) {
      t /= 20;
      move = (move - tMove) / 10 + tMove;
     } else if (move < bMove) {
      t /= 20;
      move = (move - bMove) / 10 + bMove;
     }
     target.style.top = move + "px";
     scroller.style.top = -move / st + 'px';
     setTimeout(inertiaMove, 10);
    }

    inertiaMove();
   })(v, nowTime, contentY);
   move = 0;
   flg = false;
  }

  //操作結束
  /**
   *相關初始化
   */
  //滾動條長度初始化
  scroller.style.height = sheight + 'px';
  //初始化結束

 },
 otherInteract : function() {
  //其他功能擴充
 }
}

IE hack css

復制代碼 代碼如下:

body,html {background-color:#333; margin: 0; height: 100%; line-height: 2.0; font-family: 'Microsoft YaHei'; overflow-y:hidden;}
#contain{margin: 0 auto; position:relative; width: 100%; max-width: 480px; _width: 480px; height: 100%; cursor: pointer !important;}
#appArea{position: absolute; width: 100%; height: 100%; overflow: hidden;  background-color: #fff;}  
#topInfo{position: absolute;top: 60px;width: 100%; height:60px; text-align: center; font-size: 18px; }
#bottomInfo{position: absolute;bottom: 0;width: 100%;}
#scrollerArea{position: absolute; right: 0; width: 1.5%; height: 100%;visibility: hidden;}
#scroller{position: absolute; top:0; width: 100%;  background-color: #aaa;}
#moveArea{position: absolute; top:0px; width: 100%; background-color: #ddd;}

HTML代碼

復制代碼 代碼如下:

<!DOCTYPE html>
<html>
 <head>
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=no">
  <link type="text/css" href="css/main.css" rel="stylesheet">
  <title>滑動回彈</title>
  <!--[if lt IE 9]>      <![endif]-->
  <noscript></noscript>
 </head>
 <body>
  <div id="contain">
   <div id="appArea">
    <div id="topInfo">
     logo or animate
    </div>
    <div id="bottomInfo">
     some imformation  2014-4-28
    </div>
    <div id="moveArea"></div>
    <div id="scrollerArea">
     <div id="scroller"></div>
    </div>
   </div>
  </div>

  <script src="js/main.js"></script>
 </body>
</html>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人亚洲精品| 国产精品视频一区国模私拍| 成人激情视频网| 欧美视频13p| 欧美性视频精品| 欧美日韩亚洲激情| 精品国产一区二区三区久久久狼| 国产国语刺激对白av不卡| 欧美日韩国产成人在线观看| 精品亚洲aⅴ在线观看| 91av在线精品| 第一福利永久视频精品| 亚洲人成免费电影| 国产视频精品va久久久久久| 色综合久久88| 日本三级韩国三级久久| 欧美—级高清免费播放| 午夜免费在线观看精品视频| 久久久亚洲网站| 亚洲自拍偷拍在线| 国产精品99久久久久久久久久久久| 久久久亚洲精品视频| 国产www精品| 97视频在线观看免费| 国产97色在线| 97久久精品视频| 欧美黄色性视频| 日韩视频第一页| 日韩中文在线中文网在线观看| 蜜臀久久99精品久久久久久宅男| 日韩欧美亚洲综合| 国产日韩在线看| 国产精品一区二区久久精品| 久久久精品一区二区三区| 欧美久久精品午夜青青大伊人| 亚洲视频视频在线| 亚洲激情在线观看| 88xx成人精品| 成人免费福利视频| 国产精品视频999| 久久69精品久久久久久久电影好| 日韩精品在线私人| 日韩av网站在线| 日韩精品中文字幕久久臀| 亚洲精品v欧美精品v日韩精品| 久久99热这里只有精品国产| 麻豆成人在线看| 国产精品扒开腿爽爽爽视频| 疯狂欧美牲乱大交777| 成人黄色网免费| 欧美午夜女人视频在线| 亚洲精品按摩视频| 亚洲片国产一区一级在线观看| 久久精品影视伊人网| 欧美裸身视频免费观看| 91精品久久久久久久久不口人| 美日韩精品免费视频| 91免费欧美精品| 国产精品福利无圣光在线一区| 久久夜色撩人精品| 欧美日韩一区免费| 性视频1819p久久| 国产ts人妖一区二区三区| 国产精品视频内| 欧美黄色www| 国产成人精品视频在线观看| 91精品国产高清久久久久久| 国产精品pans私拍| 国产精品久久久久99| 欧美在线视频一区二区| 亚洲第一区第二区| 国产69久久精品成人看| 中文在线不卡视频| 精品国产乱码久久久久久虫虫漫画| 欧美激情一级欧美精品| 2018国产精品视频| 亚洲免费视频一区二区| 国产精品久久网| 久久久免费观看视频| 日本欧美在线视频| 亚洲精品永久免费| 欧美成人性生活| 中文字幕久久亚洲| 原创国产精品91| 欧美大成色www永久网站婷| 日本一欧美一欧美一亚洲视频| 懂色av影视一区二区三区| 久久精品久久久久久| 国产欧美日韩最新| 国产精品视频免费观看www| 国产丝袜一区二区三区| 欧美电影第一页| 日韩欧美在线字幕| 亚洲热线99精品视频| 国产精品女主播| 国产日韩欧美电影在线观看| 91精品视频在线播放| 欧美国产极速在线| 亚洲国产欧美一区二区丝袜黑人| 日韩毛片中文字幕| 中文字幕一区日韩电影| 成人国产在线视频| 欧美激情网站在线观看| 午夜精品福利视频| 日韩精品日韩在线观看| 国产精品成人av性教育| 福利精品视频在线| 久久视频中文字幕| 日韩精品高清在线| 久久夜精品va视频免费观看| 日韩欧美高清视频| 国产精选久久久久久| 亚洲精品短视频| 欧美精品在线观看91| 欧美午夜精品久久久久久浪潮| 亚洲r级在线观看| 免费99精品国产自在在线| 国产免费一区视频观看免费| 狠狠躁夜夜躁人人爽天天天天97| 国产精品久久久久不卡| 国产精品美女呻吟| 国产成人综合久久| 欧美性在线视频| 日韩精品视频在线免费观看| 国产99久久精品一区二区永久免费| 亚洲美女av电影| 欧美在线观看www| 国产情人节一区| 久久免费成人精品视频| 成人激情视频小说免费下载| 亚洲va男人天堂| 丝袜情趣国产精品| 欧美日韩在线视频一区二区| 国产精品久久久久久久久久99| 亚洲天堂av在线免费观看| 日本国产欧美一区二区三区| 精品欧美国产一区二区三区| 人九九综合九九宗合| 一本色道久久综合亚洲精品小说| 久久综合伊人77777| 奇米4444一区二区三区| 欧美高清视频在线观看| 日韩精品久久久久| 国产精品黄色影片导航在线观看| 国产精品久久久久av| 热久久这里只有精品| 69**夜色精品国产69乱| 亚洲桃花岛网站| 国产在线播放不卡| 亚洲欧美综合精品久久成人| 国产精品久久综合av爱欲tv| 亚洲成人免费网站| 国产精品美腿一区在线看| 日本精品视频在线| 久久噜噜噜精品国产亚洲综合| 亚洲人高潮女人毛茸茸| 日韩最新av在线| 欧美激情精品久久久久| 国产精品户外野外| 欧美性高潮床叫视频| 久久精品免费播放| 欧美日韩亚洲一区二区| 欧美黑人极品猛少妇色xxxxx| 亚洲丝袜一区在线|