微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.页面内容
<div class="list">
    <div class="item">
        <button class="button button-balanced" ng-click="show($event);">加载</button>
    </div>
</div>
<ion-content overflow-scroll="false">{{content}}</ion-content>

3.使用实例

var app = angular.module('myApp',['ionic']);
//全局配置加载动作
app.constant('$ionicLoadingConfig',{
    template: '<ion-spinner icon="lines" class="spinner-calm"></ion-spinner>',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 $http 请求服务整理

AngularJs constant()和value()

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐