我想使用与用户素材相关联的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
});
}
});
答案 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
});
}
});
}
}
});