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

javascript – AngularJS服务并承诺最佳实践

我有一个AngularJS应用程序,我有调用$http资源的服务,并返回我在控制器中解析的承诺.以下是我正在做的一个示例:

app.service('Blog', function($http, $q) {
  var deferred = $q.defer();
  $http.get('http://blog.com/sampleblog')
    .then(function(res) {
        // data massaging stuffs
      return deferred.resolve(res.data);
    }, function(err) {
        // may be some error message checking and beautifying error message
      return deferred.reject(err);
    });
    // chain if further more HTTP calls
  return deferred.promise;
});

但我也可以简单地做以下事情:

app.service('Blog', function($http) {
  return $http.get('http://blog.com/sampleblog');
});

然后在控制器级别进行验证,错误美化,链接承诺等.

我的问题是:在代码弹性和灵活性方面,哪个被认为是“最佳实践”?或者有更好的方法来完成与此完全不同的方式吗?

解决方法:

根据MVC背后的概念,控制器应该决定如何处理承诺.

该服务应该发起承诺.

app.service('Blog', function($http) {
  return $http.get('http://blog.com/sampleblog');
});

并且控制器应该在解决时决定做什么.

$scope.response = Blog;

$scope.response.then(function(response) {
    DataProcessor.processData(response.data)
})
.error(function(error){
    ErrorHandler.handle(error);
})

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

相关推荐