javascript - RestAngular:put 和 customPUT 正在发送旧对象,而不是更新对象

标签 javascript angularjs rest restangular

当我调用 putcustomPUT 并在浏览器中检查请求正文时,发送的是原始对象,而不是更新后的对象。我用 {{ object }} 检查了 RestAngular 对象,它正在被更新。

这是 Controller (APIUsers 是一个 RestAngular 服务):

$scope.objects = {};
(function waitForNgInit(fnct) {
    $scope.$watch('userID', function(newVal) {
        if (newVal !== undefined) {
            fnct();
        }
    });
})(function retrieveUser() {
    $scope.objects.user = APIUsers.one($scope.userID).get().$object;
});

$scope.saveSettings = function() {
    $scope.objects.user.customPUT($scope.objects.user).then(function(resp) {
        $scope.errors = [];
    }, function(err) {
        console.log(err.data);
        $scope.errors = err.data.errors;
    });
};

这是 Jade(HTML 模板代码):

div.user-settings.form-section(ng-controller="userSettingsFormController")
    {{ objects }}
    ul.error-box(ng-show="errors != undefined && errors.legnth != 0")
        li(ng-repeat="error in errors") {{ error.msg }}
    .form-group
        label(for="username") Username
        input(type="textfield" ng-model="objects.user.username")
    .form-group
        label(for="username") Email
        input(type="textfield" ng-model="objects.user.email")
    .form-group
        label(for="username") Profile Picture
        input(type="file" ng-model="objects.user.profilePicture")
    span.submit-button(ng-click="saveSettings()") Save Changes

最佳答案

这是一个古老且已知的 Restangular 错误,请参阅 https://github.com/mgonto/restangular/issues/713

要同时修复此问题(似乎正在修复它),您可以使用以下代码:

$scope.submit = function submit() {
    Restangular
      .copy($scope.ledger)
      .save()
      .then(function () {
        growl.success(gettext('Updated successfully.'));
      });
  };

关于javascript - RestAngular:put 和 customPUT 正在发送旧对象,而不是更新对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24462594/

相关文章:

javascript - AngularJs 中带有嵌套 ui-view 的体面的 Url

javascript - Backbone.js、Rest API 和匿名 session

javascript - html5 FileReader , readAsDataUrl 函数返回什么样的数据?是网址吗?还是数据本身?

javascript - 当 native HTML5 日期输入类型不存在时加载 jQuery UI 日期选择器

javascript - React Native - 根据其父答案处理动态表单

javax.ws.rs.Produces 在 Spring 中等效

PHP - 带有分页功能的 Twitter API (OAuth) 无法正常工作

javascript - 从 webgrid 获取 row 中的值并将其传递给 Controller

javascript - 下拉菜单切换不适用于 ngTouch

javascript - 语法错误 : expected expression, 在 AngularJS 路由刷新时得到 '<'