给定某个SharePoint Online列表的命名视图,如何使用TypeScript检索视图的项目,该TypeScript是与该列表在同一租户中运行的Web部件的一部分?
使用:
import { SPHttpClient, SPHttpClientResponse, ISPHttpClientOptions } from '@microsoft/sp-http';
并给出:
List: List1
和
View: View1
此SPFX REST API代码:
const executeJson = (endpointUrl, payload) => {
const opt: ISPHttpClientOptions = { method: 'GET' };
if (payload) {
opt.method = 'POST';
opt.body = JSON.stringify(payload);
}
return this.context.spHttpClient.fetch(endpointUrl, SPHttpClient.configurations.v1, opt);
};
const getListItems = (webUrl,listTitle, queryText) => {
var viewXml = '<View><Query>' + queryText + '</Query></View>';
var endpointUrl = webUrl + "/_api/web/lists/getbytitle('" + listTitle + "')/getitems";
var queryPayload = {'query' : { 'ViewXml' : viewXml } };
return executeJson(endpointUrl, queryPayload);
};
const getListViewItems = (webUrl,listTitle,viewTitle) => {
var endpointUrl = webUrl + "/_api/web/lists/getByTitle('" + listTitle + "')/Views/getbytitle('" + viewTitle + "')/ViewQuery";
return executeJson(endpointUrl, null).then((response: SPHttpClientResponse) => { return response.json(); })
.then(data => {
var viewQuery = data.value;
return getListItems(webUrl,listTitle,viewQuery);
});
};
const url = this.context.pageContext.site.absoluteUrl;
getListViewItems(url,'List1','View1')
.then((response: SPHttpClientResponse) => { return response.json(); })
.then(response=>{
for (var item of response.value) {
console.log(item);
}
});
将列表视图的项目打印到控制台。
希望您获得使用类型脚本在SharePoint中显示列表视图的代码。