javascript - 类型错误 : undefined is not a function in Angular Resource

标签 javascript angularjs angularjs-directive angularjs-scope angularjs-resource

当尝试在 AngularJS 资源上轮询自定义方法 copies 时,我在 angular.js:10033 处收到以下错误:(方法 copy 工作得很好。)

TypeError: undefined is not a function
at https://code.angularjs.org/1.3.0-beta.8/angular-resource.min.js:9:347
at Array.forEach (native)
at q (https://code.angularjs.org/1.3.0-beta.8/angular.min.js:7:280)
at q.then.p.$resolved (https://code.angularjs.org/1.3.0-beta.8/angular-resource.min.js:9:329)
at J (https://code.angularjs.org/1.3.0-beta.8/angular.min.js:101:5)
at J (https://code.angularjs.org/1.3.0-beta.8/angular.min.js:101:5)
at https://code.angularjs.org/1.3.0-beta.8/angular.min.js:102:173
at g.$eval (https://code.angularjs.org/1.3.0-beta.8/angular.min.js:113:138)
at g.$digest (https://code.angularjs.org/1.3.0-beta.8/angular.min.js:110:215)
at g.$apply (https://code.angularjs.org/1.3.0-beta.8/angular.min.js:113:468)

Angular.js 10016 - 10035:

function consoleLog(type) {
  var console = $window.console || {},
      logFn = console[type] || console.log || noop,
      hasApply = false;

  // Note: reading logFn.apply throws an error in IE11 in IE8 document mode.
  // The reason behind this is that console.log has type "object" in IE8...
  try {
    hasApply = !!logFn.apply;
  } catch (e) {}

  if (hasApply) {
    return function() {
      var args = [];
      forEach(arguments, function(arg) {
        args.push(formatError(arg));
      });
      return logFn.apply(console, args); // This is line 10033 where the error gets thrown.
    };
  }

简化的资源:

angular.module('vgm.content-pages')
.factory('ContentPage', function($resource, $http) {

  return $resource('/api/content-page/:id', { id:'@page.id' }, {
    copy: {
      method: 'POST',
      url: '/api/content-page/copy/:id'
    },
    copies: {
      method: 'GET',
      isArray: true,
      url: '/api/content-page/copies/:id'
    }
  });

});

出现错误的简化指令:

angular.module('vgm.genericForms')
.directive('vgmFormCopyPicker', function() {

  return {
    restrict: 'E',
    replace: true,
    templateUrl: '/static/common/generic-forms/widgets/view-copy-picker.html',
    scope: {
      resource: '=',
    },
    controller: function($scope, $element) {

      $scope.pages = [];

      $scope.loadCopies = function() {

        $scope.resource.$copies()
          .then(function(response) {
            $scope.pages = response.data;
          });

      };

    }
  };

});

一旦我运行 loadCopies 方法,执行 $scope.resource.$copies() 行就会抛出上述错误。

在 Chrome 检查器中,我看到对我的 API 的调用实际上已经完成。但是解决 promise 似乎会引发一些错误......

我该如何解决这个错误?

编辑:

$scope.resource = ContentPage.get({id: $stateParams.id}).$promise
$scope.resource.$save() // Works
$scope.resource.$update() // Works
$scope.resource.$copy() // Works
$scope.resource.$copies() // Does not work!

Angular Resource 试图用一组项目覆盖我的初始资源。但是 Resource 的实例当然没有方法 push

最佳答案

我找到了答案:

资源应该在其剩余生命周期内代表匹配的数据对象。如果你想获取新数据,你应该使用一个新对象。

$scope.copies = ContentPage.copies()

关于javascript - 类型错误 : undefined is not a function in Angular Resource,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23609162/

相关文章:

javascript - React Native Android FlatList onScroll 动画

javascript - Shiny 的数据表回调

angularjs - 如何使用 Protractor 识别 ionic 标签?

html - 如何在 AngularJS 自定义指令中对 Angular 移动父 <div>

angularjs - 嵌入指令中的访问父范围

javascript - AngularJS - ngModel 与自定义指令冲突

javascript - 使用 TypeScript 按值排序对象数组

javascript - node.js req.body 在express 4.16.X、body-Parser 1.X 中未定义

javascript - Angular OrderBy 索引不起作用

javascript - 解析完成后如何将内容从服务传递到 Controller ?