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

angularjs實(shí)現(xiàn)上拉加載和下拉刷新數(shù)據(jù)功能

 更新時(shí)間:2017年06月12日 14:30:41   作者:過去式的美好  
本篇文章主要介紹了angularjs實(shí)現(xiàn)上拉加載和下拉刷新數(shù)據(jù)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

雖說AngularJS 1.x版本中對于上拉加載,下拉刷新數(shù)據(jù)功能都有做些封裝,但還是有些人不清楚。其實(shí)我一開始也是不懂的,so.現(xiàn)在把搞懂的記錄下免得少走彎路。

now,begin:先說下拉刷新吧,原理就是每次下拉都重新去服務(wù)器請求過一次新的數(shù)據(jù)。一般這種刷新功能的響應(yīng)數(shù)據(jù)(也就是服務(wù)器返回的(json)數(shù)據(jù))中都會(huì)帶有

"rowsOfPage": 3,
    "currentPage": 1,
    "totalPages": 10,
    "totalRows": 40,
    "rowsOfPage":10,
    "minRowNumber": 1,
    "maxRowNumber": 3,

這樣的屬性字段。所以我們下拉刷新時(shí)只要把請求參數(shù)設(shè)置為currentPage:1,rowsOfPage:10。也就是要設(shè)置當(dāng)前頁始終的值為1,一頁要顯示多少行。然后把返回的data保存在一個(gè)數(shù)組中,其實(shí)這樣基本就算是完成了這功能,但為了嚴(yán)謹(jǐn)些我們最好再判斷下這個(gè)數(shù)組的長度是否小于總條數(shù)。再在這判斷里面再判斷下這個(gè)數(shù)組長度是否等于0,如果是就說明沒有數(shù)據(jù)。我這邊就直接賦值一下下拉刷新的執(zhí)行代碼。

$scope.hasMore = false;
    //   $scope.dataNull=false;   // 無數(shù)據(jù)提示
    $scope.SName = "您當(dāng)前沒有待辦事務(wù)";
    $scope.do_refresher = function() {
      $scope.currentPage = 1;
      $scope.bItems = [];
      ajax.post(reqUrl, {
        "rowsOfPage": rowsOfPage,
        "currentPage": $scope.currentPage
      }, function(listdata, successful) {
        if (successful) {
          $scope.bItems = listdata.datas || [];
          $scope.hasMore = ($scope.bItems.length < listdata.totalRows);
          if ($scope.bItems.length == 0) {
            $scope.dataNull = true;
          } else {
            $scope.dataNull = false;
          }
        } else {
          $scope.hasMore = false;
        }
        $scope.$broadcast("scroll.refreshComplete");
      });

而在頁面中只要調(diào)用下<ion-refresher pulling-text="下拉刷新..." on-refresh="do_refresher()"></ion-refresher> 就可以了,其中$scope.$broadcast("scroll.refreshComplete");這個(gè)的作用是請求到數(shù)據(jù)刷新頁面。

接下來是上拉加載數(shù)據(jù)功能。這個(gè)會(huì)比下拉刷新麻煩一點(diǎn),但都懂了話也還好。上拉加載原理理解:請求的currentPage參數(shù)值為累加1.把請求到數(shù)據(jù)用push方法循環(huán)加到已有數(shù)據(jù)的數(shù)組中。這是理想的數(shù)據(jù),我們平常在開發(fā)中還要判斷這個(gè)是否有數(shù)據(jù)加載。我就先上下代碼再說明應(yīng)該會(huì)更好理解:

/*
     * 上拉加載,分批加載服務(wù)端剩余的數(shù)據(jù)
     */
    $scope.do_infinite = function() {
      if (!$scope.hasMore) {
        $scope.$broadcast("scroll.infiniteScrollComplete");
        return;
      }
      // 如果當(dāng)前頁數(shù)大于等于總頁數(shù),說明已經(jīng)沒數(shù)據(jù)可再加載了。
      $scope.currentPage += 1;

      ajax.post(reqUrl, {
        "rowsOfPage": rowsOfPage,
        "currentPage": $scope.currentPage
      }, function(listdata, successful) {
        if (successful) {
          //window.debug && alert("length " + listdata.datas.length + " yeshu " + $scope.currentPage);
          $scope.currentPage = listdata.currentPage;
          for (var i = 0; i < listdata.datas.length; i++) {
            $scope.bItems.push(listdata.datas[i]);
          }
          $scope.hasMore = ($scope.bItems.length < listdata.totalRows);
        } else {
          $scope.hasMore = false;
        }
        $scope.$broadcast("scroll.infiniteScrollComplete");
      });

其中hasmore是布爾值判斷是否還有更多數(shù)據(jù)。然后在請求參數(shù)currentPage的值是用累加的。用for循環(huán)把返回的數(shù)據(jù)push到已有數(shù)據(jù)的數(shù)組中,再判斷當(dāng)前的數(shù)組長度(也就是獲取到本地的總條數(shù))是否等于請求到返回?cái)?shù)據(jù)總條數(shù)屬性的值。如果這布爾值為true說明還有數(shù)據(jù)。同上 $scope.$broadcast("scroll.infiniteScrollComplete"); 也是刷新頁面數(shù)據(jù)。在頁面中只要在ion-list下面添加<ion-infinite-scroll ng-if="hasMore" on-infinite="do_infinite()" immediate-check="false"></ion-infinite-scroll> 就可以執(zhí)行。

note:在html頁面中,下拉刷新的功能要放在ion-list上面這里寫圖片描述,

上拉加載則放在ion-list下面這里寫圖片描述 有圖片總不會(huì)理解錯(cuò)了。

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

相關(guān)文章

  • AngularJS的依賴注入實(shí)例分析(使用module和injector)

    AngularJS的依賴注入實(shí)例分析(使用module和injector)

    這篇文章主要介紹了AngularJS的依賴注入,結(jié)合實(shí)例形式分析了依賴注入的原理及使用module和injector實(shí)現(xiàn)依賴注入的步驟與操作技巧,需要的朋友可以參考下
    2017-01-01
  • angular內(nèi)容投影詳解

    angular內(nèi)容投影詳解

    這篇文章主要為大家介紹了angular內(nèi)容投影,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • 對angularJs中ng-style動(dòng)態(tài)改變樣式的實(shí)例講解

    對angularJs中ng-style動(dòng)態(tài)改變樣式的實(shí)例講解

    今天小編就為大家分享一篇對angularJs中ng-style動(dòng)態(tài)改變樣式的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • AngularJS實(shí)現(xiàn)樹形結(jié)構(gòu)(ztree)菜單示例代碼

    AngularJS實(shí)現(xiàn)樹形結(jié)構(gòu)(ztree)菜單示例代碼

    這篇文章運(yùn)用示例代碼給大家詳細(xì)介紹了利用AngularJS如何實(shí)現(xiàn)樹形結(jié)構(gòu)(ztree)菜單,文中僅用了幾行AngularJS代碼就是了這個(gè)功能,對大家日常開發(fā)很有幫助,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-09-09
  • angularjs請求數(shù)據(jù)的方法示例

    angularjs請求數(shù)據(jù)的方法示例

    這篇文章主要給大家介紹了關(guān)于angularjs請求數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用angularjs具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 簡單說說angular.json文件的使用

    簡單說說angular.json文件的使用

    這篇文章主要介紹了簡單說說angular.json文件的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10
  • 基于AngularJS實(shí)現(xiàn)iOS8自帶的計(jì)算器

    基于AngularJS實(shí)現(xiàn)iOS8自帶的計(jì)算器

    這篇文章的主要內(nèi)容是使用angularjs實(shí)現(xiàn)一個(gè)計(jì)算器,是一個(gè)仿iOS8風(fēng)格的計(jì)算器,功能基本和iOS自帶的計(jì)算器是一致的。有需要的朋友們可以參考借鑒。
    2016-09-09
  • Angular.js中上傳指令ng-upload的基本使用教程

    Angular.js中上傳指令ng-upload的基本使用教程

    這篇文章主要給大家介紹了關(guān)于Angular.js中上傳指令ng-upload的基本使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • 淺談angular2路由預(yù)加載策略

    淺談angular2路由預(yù)加載策略

    這篇文章主要介紹了淺談angular2路由預(yù)加載策略,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • AngularJS 中括號的作用詳解

    AngularJS 中括號的作用詳解

    這篇文章主要介紹了AngularJS 中括號的作用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04

最新評論