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

H5基于iScroll實現(xiàn)下拉刷新和上拉加載更多

 更新時間:2017年07月18日 09:23:10   作者:garfieldzf  
這篇文章主要為大家詳細(xì)介紹了H5基于iScroll實現(xiàn)下拉刷新和上拉加載更多效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言

      前一段有個手機(jī)端的項目需要用到下拉刷新和上拉加載更多的效果,腦海里第一反映就是微博那種效果,剛開始的理解有些偏差,以為下拉也是追加數(shù)據(jù),上拉也是追加數(shù)據(jù),后請教同事后發(fā)現(xiàn)其實下拉只是刷新最新數(shù)據(jù)而已,上拉是追加數(shù)據(jù)。

使用技巧

      1、引用iScroll.js, 在初始化時添加兩個事件監(jiān)聽:touchMove、DOMContentLoaded。

      2、實現(xiàn)iScroll插件的onScrollEnd事件, 也就是在這個事件里調(diào)用你自己的ajax方法實現(xiàn)數(shù)據(jù)的刷新和追加。

      3、上拉加載更多請求后臺時就相當(dāng)于分頁請求數(shù)據(jù),這時候需要在ajax請求時發(fā)送pageIndex參數(shù),而初始化加載時需要從后臺返回一個pageCount以便前臺判斷。

      4、最關(guān)鍵的就是實現(xiàn)下拉刷新方法(pullDownAction)和上拉加載更多(pullUpAction)方法。

效果圖

 

實現(xiàn)方法

var   myScroll,
  pullDownEl, pullDownOffset,
  pullUpEl, pullUpOffset,
  generatedCount = 0;
 
/**
 * 下拉刷新 (自定義實現(xiàn)此方法)
 * myScroll.refresh(); 數(shù)據(jù)加載完成后,調(diào)用界面更新方法
 */
function pullDownAction () {
  setTimeout(function () {  
    var el, li, i;
    el = document.getElementById('thelist');
 
    for (i=0; i<3; i++) {
      li = document.createElement('li');
      li.innerText = 'Generated row ' + (++generatedCount);
      el.insertBefore(li, el.childNodes[0]);
    }
     
    myScroll.refresh();   //數(shù)據(jù)加載完成后,調(diào)用界面更新方法 
  }, 1000); 
}
 
/**
 * 滾動翻頁 (自定義實現(xiàn)此方法)
 * myScroll.refresh();   // 數(shù)據(jù)加載完成后,調(diào)用界面更新方法
 */
function pullUpAction () {
  setTimeout(function () {  // <-- Simulate network congestion, remove setTimeout from production!
    var el, li, i;
    el = document.getElementById('thelist');
 
    for (i=0; i<3; i++) {
      li = document.createElement('li');
      li.innerText = 'Generated row ' + (++generatedCount);
      el.appendChild(li, el.childNodes[0]);
    }
     
    myScroll.refresh();   //數(shù)據(jù)加載完成后,調(diào)用界面更新方法
  }, 1000); 
}
 
/**
 * 初始化iScroll控件
 */
function loaded() {
  pullDownEl = document.getElementById('pullDown');
  pullDownOffset = pullDownEl.offsetHeight;
  pullUpEl = document.getElementById('pullUp'); 
  pullUpOffset = pullUpEl.offsetHeight;
   
  myScroll = new iScroll('wrapper', {
    scrollbarClass: 'myScrollbar',
    useTransition: false,
    topOffset: pullDownOffset,
    onRefresh: function () {
      if (pullDownEl.className.match('loading')) {
        pullDownEl.className = '';
        pullDownEl.querySelector('.pullDownLabel').innerHTML = '下拉刷新...';
      } else if (pullUpEl.className.match('loading')) {
        pullUpEl.className = '';
        pullUpEl.querySelector('.pullUpLabel').innerHTML = '上拉加載更多...';
      }
    },
    onScrollMove: function () {
      if (this.y > 5 && !pullDownEl.className.match('flip')) {
        pullDownEl.className = 'flip';
        pullDownEl.querySelector('.pullDownLabel').innerHTML = '松手開始更新...';
        this.minScrollY = 0;
      } else if (this.y < 5 && pullDownEl.className.match('flip')) {
        pullDownEl.className = '';
        pullDownEl.querySelector('.pullDownLabel').innerHTML = '下拉刷新...';
        this.minScrollY = -pullDownOffset;
      } else if (this.y < (this.maxScrollY - 5) && !pullUpEl.className.match('flip')) {
        pullUpEl.className = 'flip';
        pullUpEl.querySelector('.pullUpLabel').innerHTML = '松手開始更新...';
        this.maxScrollY = this.maxScrollY;
      } else if (this.y > (this.maxScrollY + 5) && pullUpEl.className.match('flip')) {
        pullUpEl.className = '';
        pullUpEl.querySelector('.pullUpLabel').innerHTML = '上拉加載更多...';
        this.maxScrollY = pullUpOffset;
      }
    },
    onScrollEnd: function () {
      if (pullDownEl.className.match('flip')) {
        pullDownEl.className = 'loading';
        pullDownEl.querySelector('.pullDownLabel').innerHTML = '加載中...';        
        pullDownAction();  // ajax call
      } else if (pullUpEl.className.match('flip')) {
        pullUpEl.className = 'loading';
        pullUpEl.querySelector('.pullUpLabel').innerHTML = '加載中...';        
        pullUpAction(); // ajax call
      }
    }
  });
   
  setTimeout(function () { document.getElementById('wrapper').style.left = '0'; }, 800);
}
 
//初始化綁定iScroll控件
document.addEventListener('touchmove', function (e) { e.preventDefault(); }, false);
document.addEventListener('DOMContentLoaded', loaded, false);

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

相關(guān)文章

  • JavaScript小技巧整理篇(非常全)

    JavaScript小技巧整理篇(非常全)

    這篇文章主要介紹了JavaScript小技巧整理篇(非常全)的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • JS中錨點鏈接點擊平滑滾動并自由調(diào)整到頂部位置

    JS中錨點鏈接點擊平滑滾動并自由調(diào)整到頂部位置

    這篇文章主要介紹了JS中錨點鏈接點擊平滑滾動并自由調(diào)整到頂部位置,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • 微信小程序自定義可滑動的tab切換

    微信小程序自定義可滑動的tab切換

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義tab切換,可滑動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JavaScript與Java正則表達(dá)式寫法的區(qū)別介紹

    JavaScript與Java正則表達(dá)式寫法的區(qū)別介紹

    這篇文章主要介紹了JavaScript與Java正則表達(dá)式寫法的區(qū)別介紹,需要的朋友可以參考下
    2017-08-08
  • JS如何實現(xiàn)手機(jī)端輸入驗證碼效果

    JS如何實現(xiàn)手機(jī)端輸入驗證碼效果

    這篇文章主要介紹了JS如何實現(xiàn)手機(jī)端輸入驗證碼效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-05-05
  • javascript結(jié)合fileReader 實現(xiàn)上傳圖片

    javascript結(jié)合fileReader 實現(xiàn)上傳圖片

    FileReader具體支持哪些方法和事件,這里就不介紹了,有興趣的可以去w3c官網(wǎng)上看看FileReader介紹,這里主要介紹一下FileReader常見應(yīng)用,以及fileReader 實現(xiàn)上傳圖片示例分享。
    2015-01-01
  • js基于myFocus實現(xiàn)輪播圖效果

    js基于myFocus實現(xiàn)輪播圖效果

    這篇文章主要為大家詳細(xì)介紹了js基于myFocus實現(xiàn)輪播圖效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • Svelte?和?React的比較詳解(一)

    Svelte?和?React的比較詳解(一)

    在這篇文章中,我將Svelte?還是?React作了對比,不能以個人意見代表誰好誰壞。以及我發(fā)現(xiàn)使用這兩個框架的一些區(qū)別,感興趣的小伙伴可以參考閱讀
    2023-04-04
  • Stop SQL Server

    Stop SQL Server

    Stop SQL Server...
    2007-06-06
  • 如何在微信小程序?qū)崿F(xiàn)一個幸運轉(zhuǎn)盤小游戲

    如何在微信小程序?qū)崿F(xiàn)一個幸運轉(zhuǎn)盤小游戲

    這篇文章主要給大家介紹了關(guān)于如何在微信小程序?qū)崿F(xiàn)一個幸運轉(zhuǎn)盤小游戲的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04

最新評論