AngularJs 自定义ajax服务为请求添加加载动画

一、此处示例使用iconic的动画加载

1.自定义ajax服务封装

//全局配置请求处理
app.service('$ajax', function ($http, $ionicLoading) {
    this.get = function (url, data, onSuccess, onError) {
        $ionicLoading.show(); //显示动画
        $http.get(url, {
            param: data
        })
        .then(function (result) {
            if (result.status == 200) {
                if (onSuccess)
                    onSuccess(result.data);
            } else {
                if (onError)
                    onError(result.data);
            }
            $ionicLoading.hide(); //隐藏动画
        }).catch(function (err) {
            console.error(err);
            if (onError)
                onError(err.data);
            $ionicLoading.hide(); //隐藏动画
        });
    }
});
2.页面内容

{{content}}

3.使用实例

var app = angular.module('myApp', ['ionic']);
//全局配置加载动作
app.constant('$ionicLoadingConfig', {
    template: '',
    animation: 'fade-in'
});
app.controller('myCtrl', function ($scope, $http, $ajax) {
    $scope.show = function ($event) {
        //显示加载
        $ajax.get('http://www.gongjuji.net', {}, function (data) {
            $scope.content = data;
        });
        $event.stopPropagation();
    }
});
显示效果:

AngularJs 自定义ajax服务为请求添加加载动画_第1张图片

AngularJs 自定义ajax服务为请求添加加载动画_第2张图片



更多:

AngularJs $http 请求服务整理

AngularJs constant()和value()

AngularJS阻止事件冒泡$event.stopPropagation()

你可能感兴趣的:(AngularJs 自定义ajax服务为请求添加加载动画)