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

首頁 > 開發 > JS > 正文

移動端如何用下拉刷新的方式實現上拉加載

2024-05-06 16:47:05
字體:
來源:轉載
供稿:網友

實現上拉加載最普遍的方式就是監聽滾動條的滾動事件,而移動端的下拉刷新利用的是transform屬性來進行位移,那用下拉刷新的方式實現上拉加載怎么樣?

html結構

<div class="main-box" id="box1">  <div class="popup-box">  </div></div><div class="main-box" id="box2">  <div class="popup-box">  </div></div>

這里我們做了兩個主要的盒子,在兩個盒子內實現上拉加載。結構很簡單。

css樣式

    * {      margin: 0;      padding: 0;    }    .main-box {      background: skyblue;      width: 100%;      height: 300px;      overflow: hidden;    }    .popup-box {      width: 100%;    }    .item {      width: 100%;      line-height: 40px;      text-align: center;      padding: 20px;      box-sizing: border-box;    }    .tips{      text-align: center;    }    #box2 {      margin-top: 50px;    }

最外面的盒子設置overflow: hidden;中間盒子不設置高度,靠子盒子item撐起。

js代碼

  /*下拉加載*/  function tDscroll(obj) {    this.key = true;         //防止重復的請求    this.dom = obj.dom;        //傳入的dom    this.fn = obj.fn;         //回調函數    this.outDom = this.dom.querySelector(".popup-box"); //獲取內容盒子    this.showHeight = dom.offsetHeight;         //顯示的高度    this.actualHeight = this.outDom.offsetHeight;       //獲取實際高度的內容    this.startY = 0;                //起始點擊位置    this.changedY = 0;               //手指移動的距離    this.originY = 0;               //偏移量    var that = this;    this.dom.addEventListener("touchstart",function (ev) {      that.onStart(ev);    });    this.dom.addEventListener("touchmove",function (ev) {      that.onMove(ev);    });    this.dom.addEventListener("touchend",function (ev) {      that.onEnd(ev);    });    this.fn.call(this,this.outDom);  };  tDscroll.prototype.onStart = function (ev) {    this.startY = ev.targetTouches[0].clientY;    var tempArr = window.getComputedStyle(this.outDom).transform.split(",");    if (tempArr.length > 2) {      this.originY = parseInt(tempArr[tempArr.length - 1]) || 0;    }  };  tDscroll.prototype.onMove = function (ev) {    this.changedY = ev.touches[0].clientY - this.startY;    var changNum = (this.originY + this.changedY);    var scrollHeight = -changNum + this.showHeight;    if (changNum > 50)return;    if (scrollHeight > this.actualHeight + 50)return;    if (scrollHeight > this.actualHeight - 50 && this.key) {      this.fn.call(this,this.outDom);    }    this.outDom.style.cssText = "transform: translateY(" + changNum + "px);";  };  tDscroll.prototype.onEnd = function() {    if ((this.originY + this.changedY) > 50 ) {      this.outDom.style.cssText = "transform: translateY(0px);transition:all .3s";    }    if (-(this.originY + this.changedY) + this.showHeight > this.actualHeight + 50) {      this.outDom.style.cssText = "transform: translateY(-"+(this.actualHeight - this.showHeight)+"px);transition:all .3s";    }  };  var dom = document.querySelector("#box1");  //獲取dom  var dom2 = document.querySelector("#box2");  //獲取dom  var obj = {    dom : dom,    fn : add  };  var obj2 = {    dom : dom2,    fn : add  };  new tDscroll(obj);  new tDscroll(obj2);  var page = 0;          //當前的頁數(模擬用)  // 模擬ajax  function add(outDom) {    var that = this;    this.key = false;    var str = "";    for (var i = 1;i < 11;i++) {      str+="<div class='item'>"+(i+((page)*10))+"</div>"    }    page++;    setTimeout(function () {      var tips = outDom.querySelector(".tips");       //獲取提升      tips && outDom.removeChild(tips); //如果不是第一次 添加      str += "<div class='tips'>加載更多</div>";      outDom.innerHTML += str;      that.actualHeight = outDom.offsetHeight;      that.key = true;    },2000)  }

原理也是很簡單,監聽手勢事件判斷是否距離足夠,足夠就可以添加數據啦~~~

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品电影网在线观看| 91免费看片网站| 疯狂做受xxxx高潮欧美日本| 久久精品国产欧美激情| 日本免费一区二区三区视频观看| 亚洲国产高清福利视频| 国产日韩视频在线观看| 亚洲一区二区中文字幕| 中文字幕久久久av一区| 91av在线播放视频| 国产精品日韩精品| 欧洲亚洲免费视频| 久久在线免费视频| 韩国国内大量揄拍精品视频| 精品国产网站地址| 欧美国产一区二区三区| 精品色蜜蜜精品视频在线观看| 欧美国产日产韩国视频| 欧美激情中文网| 国产精品91久久久久久| 亚洲国产欧美在线成人app| 日韩在线视频中文字幕| 亚洲图片在线综合| 久久久久久久久久久免费| 欧美激情国产日韩精品一区18| 国产精品白嫩初高中害羞小美女| 亚洲福利视频网| 亚洲精品美女在线观看播放| 亚洲国产精品成人va在线观看| 欧美成人中文字幕在线| 欧美日韩中国免费专区在线看| 日韩亚洲欧美成人| 精品露脸国产偷人在视频| 在线中文字幕日韩| 国产一区二区三区视频免费| 91性高湖久久久久久久久_久久99| 亚洲午夜精品久久久久久性色| 亚洲欧美日韩爽爽影院| 法国裸体一区二区| 久久久精品网站| 欧美日本中文字幕| 午夜精品蜜臀一区二区三区免费| 欧美精品第一页在线播放| 国产精品69av| 亚洲精品理论电影| 欧美大胆a视频| 最近2019中文免费高清视频观看www99| 18一19gay欧美视频网站| 岛国精品视频在线播放| 91精品国产91久久久久久不卡| 成人久久久久爱| 色黄久久久久久| 美女黄色丝袜一区| 亚洲999一在线观看www| 国产噜噜噜噜久久久久久久久| 亚洲无线码在线一区观看| 欧美成人剧情片在线观看| 成人疯狂猛交xxx| 91久久嫩草影院一区二区| 亚洲人成网站免费播放| 久精品免费视频| 欧美极品在线播放| 久久久久久久影视| 韩国三级日本三级少妇99| 一区二区三区www| 日韩欧美视频一区二区三区| 欧美激情二区三区| 久久亚洲精品中文字幕冲田杏梨| 欧美在线视频播放| 91久久久国产精品| 精品国产一区二区三区久久久| 欧美在线影院在线视频| 国产精品1区2区在线观看| 亚洲影视九九影院在线观看| 久久精品中文字幕电影| 亚洲韩国欧洲国产日产av| 欧美性猛交视频| 国产精品自产拍在线观看中文| 国产一区二区丝袜| 日本免费久久高清视频| 亚洲综合国产精品| 97视频在线观看免费| 97久久超碰福利国产精品…| 中文字幕亚洲综合久久| 91牛牛免费视频| 日韩av不卡在线| 96sao精品视频在线观看| 久久亚洲成人精品| 狠狠色狠狠色综合日日五| 亚洲国产精彩中文乱码av在线播放| 午夜精品久久久久久久白皮肤| 亚洲国产精品字幕| 欧美精品在线第一页| 日韩精品极品在线观看| 欧美精品成人91久久久久久久| 国产91色在线免费| 欧美大片大片在线播放| 色悠悠国产精品| 久久资源免费视频| 欧美wwwwww| 永久555www成人免费| 久久久久久久久91| 国产精品第二页| 成人写真视频福利网| 国产精品久久久久久久电影| 国产欧美日韩中文| 国产91精品青草社区| 宅男66日本亚洲欧美视频| 欧美专区在线观看| 亚洲区免费影片| 日韩在线免费高清视频| 欧美成人合集magnet| 日韩黄色av网站| 日本19禁啪啪免费观看www| 91深夜福利视频| 中文字幕久精品免费视频| 欧美理论电影网| 欧美成人精品不卡视频在线观看| 精品免费在线观看| 成人激情视频在线观看| 中文字幕日韩欧美| 欧美乱大交做爰xxxⅹ性3| 国产日韩视频在线观看| 国产欧美一区二区三区四区| 日韩**中文字幕毛片| 欧美中文字幕在线播放| 黑人狂躁日本妞一区二区三区| 国产精品美女主播| 亚洲iv一区二区三区| 国产精品爱久久久久久久| 久久五月天综合| 精品久久国产精品| 欧美成人剧情片在线观看| 欧美成人国产va精品日本一级| 久久亚洲精品视频| 午夜免费日韩视频| 热久久免费国产视频| 国产日韩在线一区| 欧美激情在线有限公司| 51精品在线观看| 成人黄色免费片| 91成人精品网站| 97在线观看免费高清| 国产精品久久久久久久久久久久| 成人黄在线观看| 国产精品久久久久久网站| 中文字幕国产精品| 正在播放欧美视频| 亚洲第一网站男人都懂| 亚洲第一网站免费视频| 国产精品日韩电影| 欧美高清视频免费观看| 91久久国产婷婷一区二区| 亚洲精品99久久久久| 亚洲欧美激情一区| 美女久久久久久久| 久久人人爽人人爽人人片亚洲| 欧美国产精品人人做人人爱| 97视频在线观看播放| 在线观看日韩专区| 日本免费一区二区三区视频观看| 日韩在线观看视频免费| 日韩精品视频在线观看网址| 欧美在线亚洲在线|