使用Rest-Api将列表项添加到列表文件夹

6

我需要用SharePoint 2013的REST API在指定的文件夹中添加一个ListItem,但我遇到了问题。

如果使用客户端对象模型,代码应该如下:

    var creationInfo = new SP.ListItemCreationInformation();
    creationInfo.FolderUrl = "/Lists/MyList/MyFolder";
    var item = list.addItem(creationInfo );



    item.update();

    ctx.executeQueryAsync(
            Function.createDelegate(this, onSuccess),
            Function.createDelegate(this, onFail));

但是当我试图通过Rest服务设置FolderUrl时

{ '__metadata' : { 'type': 'SP.Data.MyListListItem' }, 'Title': 'NewItemInFolder', 'FolderUrl': '/sites/example/Lists/MyList/MyFolder' }

我收到了一个400 Bad Request的错误。

我尝试先将一个ListItem添加到列表中,然后再更新FolderUrl,但这也不起作用。

如何使用Rest-Api在SharePoint中向列表文件夹添加ListItem?

编辑:

 { '__metadata' : { 
            'type': 'SP.Data.MyListListItem',
            'type': 'SP.Data.ListItemCreationInformation'
    }, 
    'Title': 'NewItemInFolder',
    'FolderUrl': '/sites/example/Lists/MyList/MyFolder'
    }

我已经尝试过使用ListItemEntityTypeFullName和我的列表实体以及ListItemCreationInformation,但我仍然只得到了400 Bad Request错误。
当我使用Fiddler查看请求时,我发现SharePoint现在忽略了我的列表实体类型SP.Data.MyListItem

你的“type”属性为什么具有值“SP.Data.MyListListItem”?应该是“SP.ListItemCreationInformation”吧? - Yevgeniy.Chernobrivets
正如MSDN链接中所述,它必须是ListItemEntityTypeFullName,这就是为什么它是MyListListItem。我将使用ListItemCreationInformation尝试它。 - Mark
我现在已经尝试过了,请看我的编辑,但没有任何效果。 - Mark
4个回答

3

您不应该使用REST API,而应该使用listdata.svc

url: /_vti_bin/listdata.svc/[Name of List]
Header:Content-Type: application/json;odata=verbose
Body: {Title: "Title", Path: "/ServerRelativeUrl"}

我遇到了同样的问题,但是使用REST api时无法与旧的svc配合使用。


2
为什么有人会认为“不应该”使用REST API? - Draghon

0
你可以考虑以下解决方案,其中包含以下3个步骤:
  • 创建一个 ListItem 资源
  • 获取关联的 File 资源,并将其移到文件夹中。

示例

function executeJson(options) 
{
    var headers = options.headers || {};
    var method = options.method || "GET";
    headers["Accept"] = "application/json;odata=verbose";
    if(options.method == "POST") {
        headers["X-RequestDigest"] = $("#__REQUESTDIGEST").val();
    }   

    var ajaxOptions = 
    {       
       url: options.url,   
       type: method,  
       contentType: "application/json;odata=verbose",
       headers: headers
    };
    if("payload" in options) {
      ajaxOptions.data = JSON.stringify(options.payload);
    }  

    return $.ajax(ajaxOptions);
}



function createListItem(webUrl,listTitle,properties,folderUrl){
    var url = webUrl + "/_api/web/lists/getbytitle('" + listTitle + "')/items";
    return executeJson({
        "url" :url,
        "method": 'POST',
        "payload": properties})
        .then(function(result){
             var url = result.d.__metadata.uri + "?$select=FileDirRef,FileRef";
             return executeJson({url : url});
        })
        .then(function(result){
             var fileUrl = result.d.FileRef;
             var fileDirRef = result.d.FileDirRef;
             var moveFileUrl = fileUrl.replace(fileDirRef,folderUrl);
             var url = webUrl + "/_api/web/getfilebyserverrelativeurl('" + fileUrl + "')/moveto(newurl='" + moveFileUrl + "',flags=1)";
             console.log(url);
             return executeJson({
                  "url" :url,
                  "method": 'POST',
                  });
        });
}

使用方法

var webUrl = _spPageContextInfo.webAbsoluteUrl;
var listTitle = "Requests";  //list title
var targetFolderUrl = "/Lists/Requests/Archive";  //folder server relative url
var itemProperties = {
    '__metadata': { "type": "SP.Data.RequestsListItem" },
    "Title": 'Request 123'
};


createListItem(webUrl,listTitle,itemProperties,targetFolderUrl)
.done(function(item)
{
    console.log('List item has been created');
})
.fail(function(error){
    console.log(JSON.stringify(error));
});

要点


-1
creationInfo.set_folderUrl("http://siteURL/Lists/Docs/Folder1");

请创建一个使用客户端对象模型在文件夹中创建列表项的示例。 - Gareth
1
那也是客户端对象模型,而不是 REST! - Mark

-1
Microsoft.SharePoint.Client.ClientContext clientContext = new Microsoft.SharePoint.Client.ClientContext("URL");

Microsoft.SharePoint.Client.List list = clientContext.Web.Lists.GetByTitle("FolderName");

var folder = list.RootFolder;

clientContext.Load(folder);

clientContext.Credentials = new NetworkCredential(username, password, domain);
clientContext.ExecuteQuery();

folder = folder.Folders.Add("ItemName");

clientContext.Credentials = new NetworkCredential(username, password, domain);
clientContext.ExecuteQuery();

1
请使用客户端对象模型进行操作,而不是我之前询问的 RESTful API。 - Mark

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接