Pregunta

Here is my js code

var MYModule = angular.module('myApp', ['ngRoute', 'myAppServices'])
    .directive('loading',   ['$http', loadingDirective])
    .config(myRouter);

angular.module('myAppServices', ['ngResource'])
    .factory('Users', function($resource) {
        return $resource('/MY/system/users');
    });

function UsersCtrl($scope, Users) {
    $scope.users = Users.query();
}

in my html code just using this

<div ng-repeat="item in users">Hello</div>

Although I am getting request in my server code at /MY/system/users but the browser is throwing error

Error: [$resource:badcfg] http://errors.angularjs.org/1.2.16/$resource/badcfg?p0=array&p1=object
    at Error (native)
¿Fue útil?

Solución

See this error documentation: https://docs.angularjs.org/error/$resource/badcfg

This occurs when angular is expecting an array or an object, and receiving the opposite. query() expects an array to be returned from your endpoint, while get() expects an object.

Also, you should change your query() syntax above to:

Users.query().then(function(result){
    $scope.users = result;
});

This is because angular is phasing out the automatic handling of promises returned via $http.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top