0

我正在尝试使用来自 mongolab 的 $resource 在 Angular 应用程序中显示数据。我在模块中添加了对 ngResource 的依赖。仍然显示未知提供者。这里缺少什么?

'$resource 未定义'

注意:当我的工厂名称不正确时,我收到错误:Unknown provider: employeesProvider <- employees

代码

<html>
<head>

<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular-resource.js"></script>

<script type="text/javascript">

 //defining module
 var app = angular.module('myApp', ['ngResource']);

 //defining factory
 app.factory('employees', function () {

    return $resource('https://api.mlab.com/api/1/databases/humanresource/collections/Employees',
                    {apiKey: 'removedmykeyforpostinginSO'}
                  );
 });

 //defining controller
 app.controller('myController', function ($scope, employees) 
 {
    $scope.countries = employees.query();
 });  

</script>
</head>

<body ng-app="myApp">
     <div ng-controller="myController">
    <ul>
        <li ng-repeat = "objCountry in countries" >
            {{objCountry.name}}

        </li>
    </ul>
     </div>
</body>
</html>

来自蒙古实验室的 JSON

[ { "_id" : { "$oid" : "57044f95e4b0427faa38585f"} , "name" : "Lijo" , "age" : "30"} ]
4

1 回答 1

0

AngulaJS 文档中,推荐的声明工厂的方式是:

angular.module('myModule', [])
.factory('serviceId', ['depService', function(depService) {
  // ...
}])

我通过注入 $resource 更正了我的工厂代码如下:

app.factory('employees', function ($resource) {

    return $resource('https://api.mlab.com/api/1/databases/humanresource/collections/Employees',
                    {apiKey: 'jJbAltZ26vuIrgzUQetXh480JM0q9k6p'}
                  );
 });

参考:

  1. $资源
  2. 用工厂和服务整理你的 Angular 控制器
  3. Angular:将数据从工厂 ajax 调用传回我的控制器
  4. 将变量从服务/工厂绑定到控制器
  5. 从工厂到控制器的角度传递数据
于 2016-06-02T12:22:11.817 回答