如何使用SharePoint Framework的TypeScript API检索列表视图的项目?

问题描述 投票:0回答:2

给定某个SharePoint Online列表的命名视图,如何使用TypeScript检索视图的项目,该TypeScript是与该列表在同一租户中运行的Web部件的一部分?

typescript rest sharepoint-online sharepoint-list sharepointframework
2个回答
0
投票

使用:

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);
    }
  });

将列表视图的项目打印到控制台。

谢谢:Vadim Gremyachev's SharePoint 2013 answer


0
投票

希望您获得使用类型脚本在SharePoint中显示列表视图的代码。

© www.soinside.com 2019 - 2024. All rights reserved.