我有一个使用 WCF 服务(在 SharePoint 中)使用数据的函数。该服务不返回项目所需的特定字段,因此我使用 SharePoint 客户端对象模型通过使用 WCF 服务返回结果中的 ID 来查询该字段。
function LoadAllNews() {
var listUrl = "/_vti_bin/ListData.svc/Pages";
$.getJSON(listUrl,
function (data) {
$.each(data.d,
function (i, result) {
GetImageUrl(result.Id, function (image) {
$(ConstructHtml(image, result.Title, result.Path, result.Name)).appendTo("#News");
});
});
});
}
当我在这里调试时result
,我总是以相同的顺序返回项目,但由于 GetImageUrl 异步执行查询,因此项目不会以相同的顺序附加。大多数情况下,他们必须有时看起来是随机的,因为获取图像的时间会有所不同:
function GetImageUrl(id, callback) {
var context = new SP.ClientContext();
var items = context.get_web().get_lists().getByTitle('Pages').getItemById(id);
context.load(items);
context.executeQueryAsync(function () {
callback(items.get_item('PublishingRollupImage'));
});
}
function ConstructHtml(imageUrl, title, path, name) {
var html = "" // a long html string..
return html;
}
我可以在 sharepoint.stackexchange 上发布此内容,但这里的受众范围更广,如何使用 JavaScript 处理这个问题比使用 SharePoint 本身更重要。
关于我应该如何处理这个问题的任何想法?我在想像跳过 LoadAllNews() 中的图像,然后在添加所有项目时使用 JavaScript/jQuery 为每个新闻项目加载图像。
提前致谢。