angularjs – 如何从角度资源$save()读取响应并保留原始数据

前端之家收集整理的这篇文章主要介绍了angularjs – 如何从角度资源$save()读取响应并保留原始数据前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我是Angular的新手.我相信我在这里缺少一些基本的东西.

我有一个对象,我发布到服务器来创建它.服务器返回对象Id,我需要读取它并更新客户端中的对象.

服务器只返回对象ID,但是,在客户端,我有其他数据,当我执行回调时我无法使用(我无法访问原始数据).

The Following jsfiddle code has been added as a reference

//Get Angular Project module
var app = angular.module("app",['ngResource']);

//create Project factory
app.factory('Project',function ($resource) {
    return $resource('http://cmsanalyticsdev.pearson.com\\:8081/api/projects/:projectid',{projectid:'@id'},{update: {method:'PUT',isArray:false}}    
    );

});


//Controller for testing
app.controller('ApplicationController',function ($scope,Project) {

//Project object
var project = new Project({"name":"New Project Test","thumbnail":"","statusid":"521d5b730f3c31e0c3b1e764","projecttypeid":"521f585c092a5b550202e536","teamid":"521f585a092a5b550202e521","authors":[{"firstname":"Dilip","lastname":"Kumar"}],"projectspecificMetadata":{"isbn13":"345345","guid":"asfas"},"modifiedby":"521f585a092a5b550202e525"}
);
//Create new project
project.$save(project,function (projectResponse) {
                        project.projectId = projectResponse._id;
                        alert(project.name);
                    });

});

解决方法

我想你想要这样的东西:

//Controller for testing
app.controller('ApplicationController',Project) {

        //Project object
        var projectData = {"name":"New Project Test","modifiedby":"521f585a092a5b550202e525"};
        var project = new Project(projectData);

        //Create new project
        project.$save(project,function (projectResponse) {
                                projectData.projectId = projectResponse.id;
                                console.log("ProjectData: %j",projectData);
                            });

    });

猜你在找的Angularjs相关文章