Angularjs的$http異步刪除數(shù)據詳解及實例
Angularjs的$http異步刪除數(shù)據詳解及實例
有人會說刪除這東西有什么可講的,寫個刪除的service,controller調用一下不就完了。
嗯...看起來是這樣,但是具體實現(xiàn)起來真的有這么簡單嗎?首先有以下幾個坑
怎么確定數(shù)據是否刪除成功?
怎么同步視圖的數(shù)據庫的內容?
1.思路
1.實現(xiàn)方式一
刪除數(shù)據庫中對應的內容,然后將$scope中的對應的內容splice
2.實現(xiàn)方式二
刪除數(shù)據庫中對應的內容,然后再reload一下數(shù)據(也就是再調用一次查詢方法,這種消耗可想而知,并且還要保證先刪除數(shù)據再查詢)
2.具體實現(xiàn)方式
刪除數(shù)據的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里面注意事項
要特別注意執(zhí)行順序:確保己經刪除完成之后再去reload數(shù)據,不然會出來視圖不更新
/** * 刪除博客 */ $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ù)據的實例詳解,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
Angular中$cacheFactory的作用和用法實例詳解
$cacheFactory是一個為Angular服務生產緩存對象的服務。接下來通過本文給大家介紹Angular中$cacheFactory的作用和用法實例詳解,非常不錯,感興趣的朋友一起看下吧2016-08-08AngularJS使用ng-options指令實現(xiàn)下拉框
這篇文章主要介紹了AngularJS使用ng-options指令實現(xiàn)下拉框效果,ng-option指令使用也很簡單,下文具體給大家說明,對angularjs 下拉框知識感興趣的朋友一起看下吧2016-08-08Angular.js實現(xiàn)注冊系統(tǒng)的實例詳解
Angular.js是Google開發(fā)的前端技術框架,最近一直在學習Angular.js,通過對angular.js的簡單理解后發(fā)現(xiàn),angular.js通過一些簡單的指令即可實現(xiàn)對DOM元素的操作,其特色為雙向數(shù)據綁定,下面這篇文章給大家詳細介紹Angular.js實現(xiàn)注冊系統(tǒng)的方法,一起來看看吧。2016-12-12