AngularJS上拉加載問(wèn)題解決方法
項(xiàng)目中始終存在一個(gè)問(wèn)題:當(dāng)在搜索欄輸入關(guān)鍵詞后(見(jiàn)圖1),按照既定的業(yè)務(wù)邏輯應(yīng)該是服務(wù)端接收到請(qǐng)求后,首先返回查詢(xún)的前7條數(shù)據(jù),待客戶(hù)端出現(xiàn)上拉加載時(shí),繼續(xù)查找另外7條數(shù)據(jù)。但實(shí)際情形是不確定的,在服務(wù)端控制臺(tái)(見(jiàn)圖2)可看到begno一直到了126,也就是相當(dāng)于客戶(hù)端往服務(wù)端請(qǐng)求了127次,這是一個(gè)令人無(wú)法忍受的結(jié)果。
圖1 客戶(hù)端搜索欄

圖2 服務(wù)端控制臺(tái)
可以斷定是客戶(hù)端的業(yè)務(wù)邏輯出現(xiàn)了問(wèn)題。返回到客戶(hù)端,查看源碼邏輯,修改如下:
控制器
$scope.medsearchMore = function() {
console.log("上拉加載....." + isfinished);
if (isfinished == 0) {
begno += pcnt;
var data = {
"begno" : begno, // 起始序號(hào)
"pagenum" : pagenum, // 每頁(yè)返回條數(shù)
"searchby": searchby
};
if (searchType == 1) {
data.classid = searchKey;
console.log(data.classid); //--------1
appCallServer($http, "9002", data, function(data) {
console.log("下拉刷新查詢(xún)結(jié)果rootScope.med:" + JSON.stringify(data.data));
for (var i = 0; i < data.pcnt; i++) {
$rootScope.med.push(data.data[i]);
}
// 更新?tīng)顟B(tài)
isfinished = data.isfinished;
// 藥品已查詢(xún)完畢
if(isfinished == '1'){
$scope.noMore = true;
}else{
$scope.noMore = false;
}
pcnt = data.pcnt;
}, function(data) {
// 藥品已查詢(xún)完畢
$scope.noMore = true;
$ionicLoading.show({
template: data.errtext
});
$timeout(function() {
$ionicLoading.hide();
}, 1200);
});
}
} else {
// 藥品已查詢(xún)完畢
$scope.noMore = true;
}
$timeout(function() {
$scope.$broadcast('scroll.infiniteScrollComplete');
}, 1200);
};
視圖
<!--當(dāng)用戶(hù)到達(dá)頁(yè)腳或頁(yè)腳附近時(shí),ion-infinite-scroll指令允許你調(diào)用一個(gè)函數(shù) 。當(dāng)用戶(hù)滾動(dòng)的距離超出底部的內(nèi)容時(shí),就會(huì)觸發(fā)你指定的on-infinite--> <!--當(dāng)沒(méi)有更多數(shù)據(jù)加載時(shí),就可以用一個(gè)簡(jiǎn)單的方法阻止無(wú)限滾動(dòng),那就是angular的ng-if指令--> <!--設(shè)置noMore初始值為true首次即點(diǎn)擊分類(lèi)查詢(xún)時(shí)不進(jìn)行下拉加載操作--> <ion-infinite-scroll on-infinite="medsearchMore()" distance="0.01%" icon="ion-loading-c"></ion-infinite-scroll> <div class="item" ng-if="noMore" align="center"><p>沒(méi)有更多的藥品了</p></div>
經(jīng)過(guò)以上修改,可以實(shí)現(xiàn)避免不必要的請(qǐng)求。

- dropload.js插件下拉刷新和上拉加載使用詳解
- vue.js移動(dòng)端app之上拉加載以及下拉刷新實(shí)戰(zhàn)
- angularjs實(shí)現(xiàn)上拉加載和下拉刷新數(shù)據(jù)功能
- JS 插件dropload下拉刷新、上拉加載使用小結(jié)
- JS+CSS實(shí)現(xiàn)下拉刷新/上拉加載插件
- 基于iscroll.js實(shí)現(xiàn)下拉刷新和上拉加載效果
- js插件dropload上拉下滑加載數(shù)據(jù)實(shí)例解析
- 純javascript實(shí)現(xiàn)簡(jiǎn)單下拉刷新功能
- iscroll.js的上拉下拉刷新時(shí)無(wú)法回彈的解決方法
- mescroll.js上拉加載下拉刷新組件使用詳解
相關(guān)文章
Angularjs material 實(shí)現(xiàn)搜索框功能
這篇文章主要介紹了Angularjs material 實(shí)現(xiàn)搜索框功能的相關(guān)資料,需要的朋友可以參考下2016-03-03
AngularJS學(xué)習(xí)第二篇 AngularJS依賴(lài)注入
這篇文章主要為大家詳細(xì)介紹了AngularJS學(xué)習(xí)第二篇,理解什么是AngularJS依賴(lài)注入,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
angular基于路由控制ui-router實(shí)現(xiàn)系統(tǒng)權(quán)限控制
這篇文章主要介紹了angular基于路由控制ui-router實(shí)現(xiàn)系統(tǒng)權(quán)限控制的相關(guān)資料,需要的朋友可以參考下2016-09-09
Angular 13+開(kāi)發(fā)模式慢的原因及構(gòu)建性能優(yōu)化解析
這篇文章主要為大家介紹了Angular 13+開(kāi)發(fā)模式慢的原因及構(gòu)建性能優(yōu)化解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Angular 開(kāi)發(fā)學(xué)習(xí)之Angular CLI的安裝使用
這篇文章主要介紹了Angular 開(kāi)發(fā)學(xué)習(xí)之Angular CLI的安裝使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
Bootstrap + AngularJS 實(shí)現(xiàn)簡(jiǎn)單的數(shù)據(jù)過(guò)濾字符查找功能
這篇文章主要介紹了 Bootstrap + AngularJS 實(shí)現(xiàn)簡(jiǎn)單的數(shù)據(jù)過(guò)濾字符查找功能,代碼簡(jiǎn)單易懂,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2017-07-07

