查询Rally中的用户故事修订版

时间:2012-10-02 16:45:49

标签: sdk rally

我想使用与用户素材相关联的URL检索修订日志的JSON对象。我使用下面的代码用jQuery完成了这个,虽然我宁愿用Rally SDK中的内置工具来做。我对Ext.Ajax或Ext.data.JsonP请求没有任何好运,虽然我觉得这是正确的方法。任何帮助将不胜感激。

$.ajax({
    url: URL,
    dataType: 'jsonp',
    jsonp: 'jsonp',
    success: function(response) {
        $.each(response.RevisionHistory.Revisions, function(key, rev) {
            //Parse Revision Log
        });
    }
});

1 个答案:

答案 0 :(得分:2)

App SDK 2.0相对简单。文档中的以下示例应该对您有所帮助:

http://developer.rallydev.com/apps/2.0p4/doc/#!/guide/appsdk_20_data_models

http://developer.rallydev.com/apps/2.0p4/doc/#!/guide/appsdk_20_data_stores

这是一个快速的小代码片段,用于获取特定故事的修订历史记录:

Rally.data.ModelFactory.getModel({
    type: 'UserStory',
    success: function(storyModel) {
        var storyRef = 'https://rally1.rallydev.com/slm/webservice/1.37/hierarchicalrequirement/12345.js';
        var storyID = Rally.util.Ref.getOidFromRef(storyRef);
        storyModel.load(storyID, {
            fetch: ['Name', 'FormattedID', 'Description', 'RevisionHistory', 'Revisions'],
            callback: function(story, operation) {
                if(story && story.get('RevisionHistory') && story.get('RevisionHistory').Revisions) {
                    Ext.Array.each(story.get('RevisionHistory').Revisions, function(revision) {
                        //Parse revision log
                    });
                }
            }
        });
    }
});

使用SDK的好处是它会自动执行ajax与jsonp请求,具体取决于您运行应用程序的方式。以上示例适用于单个故事。如果您想解析多个故事,您需要使用商店而不是model.load:

Ext.create('Rally.data.WsapiDataStore', {
    model: 'UserStory',
    autoLoad: true,
    fetch: ['Name', 'FormattedID', 'Description', 'RevisionHistory', 'Revisions'],    
    listeners: {
        load: function(store, stories) {
            Ext.Array.each(stories, function(story) { 
                if(story && story.get('RevisionHistory') && story.get('RevisionHistory').Revisions) {
                    Ext.Array.each(story.get('RevisionHistory').Revisions, function(revision) {
                        //Parse revision log
                    });
                }
            });
        }
    } 
});