要實現這個功能,可以透過 https://github.com/sroze/ngInfiniteScroll 這個第三方控制項來實現。步驟如下:
1. 下載ng-infinite-scroll.js程式 http://sroze.github.io/ngInfiniteScroll/ 目前版本是1.0.0
2. 如果你是用的jQuery2.0以上版本,還需要修改ng-infinite-scroll.js程序,將所有的將所有的$window.xxx改為$(window) .xxx, elem.xxx改為$(elem).xxx
3. 在HTML中引入script
4. HTML範例程式碼如下:
<div ng-controller='PostListController'> <div infinite-scroll='demo.nextPage()' infinite-scroll-disabled='demo.busy' infinite-scroll-distance=''> <div ng-repeat='item in demo.items'> <p> <input type="hidden" value="{{item.PostId}}" /> <label>{{item.WriterName}}</label> <label>{{item.WriterMail}}</label> <label>{{item.WreckerName}}</label> <label>{{item.StartDate}}</label> <label>{{item.Location}}</label> <label>{{item.Story}}</label> </p> </div> <div ng-show='demo.busy'>Loading data...</div> </div> </div>
5. PostListController.js程式碼如下:
var ftitAppModule = angular.module('ftitApp', ['infinite-scroll']); ftitAppModule.controller('PostListController', function ($scope, Demo) { $scope.demo = new Demo(); }); // 创建后台数据交互工厂 ftitAppModule.factory('Demo', function ($http) { var Demo = function () { this.items = []; this.busy = false; this.after = ''; this.page = ; }; Demo.prototype.nextPage = function () { if (this.busy) return; this.busy = true; var url = "http://...:/api/post/nextpage?id=" + this.page + "&callback=JSON_CALLBACK"; $http.jsonp(url).success(function (data) { var items = data; for (var i = ; i < items.length; i++) { this.items.push(items[i]); } this.after = "t_" + this.items[this.items.length - ].id; this.busy = false; this.page += ; }.bind(this)); }; return Demo; });
這樣就實現了頁面拖曳到底後,從伺服器自動載入資料的功能。
PS:AngularJS的載入執行過程
1. HTML頁面的加載,這會觸發加載頁麵包含的所有JS (包括 AngularJS)
2. AngularJS啟動,搜尋所有的指令(directive)
3. 找到ng-app,搜尋其指定的模組(Module),並將其附加到ng-app所在的元件上。
4. AnguarJS遍歷所有的子元件,找出指令和bind指令
5. 每次發現ng-controller或ng-repeart的時候,它會建立一個作用域(scope),這個作用域就是組件的上下文。作用域指明了每個DOM元件對函數、變數的存取權。
6. AngularJS接著會加入變數的監聽器,並監控每個變數的目前值。一旦值發生變化,AngularJS會更新其在頁面上的顯示。
7. AngularJS優化了檢查變數的演算法,它只會在某些特殊的事件觸發時,才會去檢查資料的更新,而不是簡單地在後台不停地輪詢。