如何在POST,PUT或DELETE请求后更新AngularJS $资源?

win*_*toy 13 angularjs

在我的Angular应用程序中,我将"项目"设置为$resource.在我的控制器中,我在页面加载时立即向服务器询问GET请求中的数据.我可以使用Angular的双向数据绑定在我的浏览器中编辑信息,然后我可以通过POST请求将数据保存回服务器,如下所示:

(为简洁起见,编辑/简化)

function ProjectCtrl($scope, $routeParams, Project) {
    $scope.project = Project.get({id: $routeParams.projectId},
        function(data) { //Successfully received data }, 
        function(data) { //Failed to receive data },
    );

    $scope.saveProject = function() {
        $scope.project.save();
    };
}
Run Code Online (Sandbox Code Playgroud)

我的节点服务器正确接收数据,处理数据并进行一些更改,将其保存到我的数据库,然后通过JSON使用新更新的"项目"对象进行响应.在刷新页面之前,Angular不显示新对象.有没有办法让它显示新数据?我假设有一种更自动的Angular方法,而不是手动调用另一个GET请求$scope.project.save();

Mic*_*ley 15

看起来服务器响应作为回调的第一个参数返回save,因此只要服务器响应完整的对象数据,您就应该能够使用它来创建一个"新的"Project对象,如下所示:

function ProjectCtrl($scope, $routeParams, Project) {
    $scope.project = Project.get({id: $routeParams.projectId},
        function(data) { /* Successfully received data */ }, 
        function(data) { /* Failed to receive data */ },
    );

    $scope.saveProject = function() {
        $scope.project.save(function(data) {
            $scope.project = new Project(data);
        });
    };
}
Run Code Online (Sandbox Code Playgroud)