Angularjs的$http異步刪除數(shù)據(jù)詳解及實(shí)例
Angularjs的$http異步刪除數(shù)據(jù)詳解及實(shí)例
有人會(huì)說刪除這東西有什么可講的,寫個(gè)刪除的service,controller調(diào)用一下不就完了。
嗯...看起來是這樣,但是具體實(shí)現(xiàn)起來真的有這么簡單嗎?首先有以下幾個(gè)坑
怎么確定數(shù)據(jù)是否刪除成功?
怎么同步視圖的數(shù)據(jù)庫的內(nèi)容?
1.思路
1.實(shí)現(xiàn)方式一
刪除數(shù)據(jù)庫中對應(yīng)的內(nèi)容,然后將$scope中的對應(yīng)的內(nèi)容splice
2.實(shí)現(xiàn)方式二
刪除數(shù)據(jù)庫中對應(yīng)的內(nèi)容,然后再reload一下數(shù)據(jù)(也就是再調(diào)用一次查詢方法,這種消耗可想而知,并且還要保證先刪除數(shù)據(jù)再查詢)
2.具體實(shí)現(xiàn)方式
刪除數(shù)據(jù)的service:用異步,返回promise
service('deleteBlogService',//刪除博客
['$rootScope',
'$http',
'$q',
function ($rootScope, $http, $q) {
var result = {};
result.operate = function (blogId) {
var deferred = $q.defer();
$http({
headers: {
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
},
url: $rootScope.$baseUrl + "/admin/blog/deleteBlogById",
method: 'GET',
dataType: 'json',
params: {
id: blogId
}
})
.success(function (data) {
deferred.resolve(data);
console.log("刪除成功!");
})
.error(function () {
deferred.reject();
alert("刪除失敗!")
});
return deferred.promise;
};
return result;
}])
controller里面注意事項(xiàng)
要特別注意執(zhí)行順序:確保己經(jīng)刪除完成之后再去reload數(shù)據(jù),不然會(huì)出來視圖不更新
/**
* 刪除博客
*/
$scope.deleteBlog = function (blogId) {
var deletePromise = deleteBlogService.operate(blogId);
deletePromise.then(function (data) {
if (data.status == 200) {
var promise = getBlogListService.operate($scope.currentPage);
promise.then(function (data) {
$scope.blogs = data.blogs;
$scope.pageCount = $scope.blogs.totalPages;
});
}
});
};
以上就是Angularjs的$http異步刪除數(shù)據(jù)的實(shí)例詳解,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
AngularJS 前臺(tái)分頁實(shí)現(xiàn)的示例代碼
本篇文章主要介紹了AngularJS 前臺(tái)分頁實(shí)現(xiàn)的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06
Angular2生命周期鉤子函數(shù)的詳細(xì)介紹
這篇文章主要介紹了Angular2生命周期鉤子函數(shù)的詳細(xì)介紹,Angular提供組件生命周期鉤子,可以讓我們更好的開發(fā)Angular應(yīng)用,有興趣的可以了解一下2017-07-07
Angular中$cacheFactory的作用和用法實(shí)例詳解
$cacheFactory是一個(gè)為Angular服務(wù)生產(chǎn)緩存對象的服務(wù)。接下來通過本文給大家介紹Angular中$cacheFactory的作用和用法實(shí)例詳解,非常不錯(cuò),感興趣的朋友一起看下吧2016-08-08
Angularjs 實(shí)現(xiàn)分頁功能及示例代碼
這篇文章主要介紹了Angularjs 實(shí)現(xiàn)分頁功能及示例代碼的相關(guān)資料,需要的朋友可以參考下2016-09-09
如何解決手機(jī)瀏覽器頁面點(diǎn)擊不跳轉(zhuǎn)瀏覽器雙擊放大網(wǎng)頁
這篇文章主要介紹了如何解決手機(jī)瀏覽器頁面點(diǎn)擊不跳轉(zhuǎn)瀏覽器雙擊放大網(wǎng)頁的相關(guān)資料,需要的朋友可以參考下2016-07-07
AngularJS使用ng-options指令實(shí)現(xiàn)下拉框
這篇文章主要介紹了AngularJS使用ng-options指令實(shí)現(xiàn)下拉框效果,ng-option指令使用也很簡單,下文具體給大家說明,對angularjs 下拉框知識(shí)感興趣的朋友一起看下吧2016-08-08
Angular.js實(shí)現(xiàn)注冊系統(tǒng)的實(shí)例詳解
Angular.js是Google開發(fā)的前端技術(shù)框架,最近一直在學(xué)習(xí)Angular.js,通過對angular.js的簡單理解后發(fā)現(xiàn),angular.js通過一些簡單的指令即可實(shí)現(xiàn)對DOM元素的操作,其特色為雙向數(shù)據(jù)綁定,下面這篇文章給大家詳細(xì)介紹Angular.js實(shí)現(xiàn)注冊系統(tǒng)的方法,一起來看看吧。2016-12-12

