以下代码成功循环遍历特定文档库中的所有文件,并输出每个文件的名称。但是,我需要枚举其他属性(不属于Document内容类型的自定义属性/列)。 get_item()
在SP.File
类型上不是有效的方法,因此我不能只传递要查找的属性名称。我怀疑我需要将Include
参数传递给.load()
方法,但是我这样做并不成功,因为它错误地告诉我我包含的属性名不存在
<script src="https://ajax.aspnetcdn.com/ajax/4.0/1/MicrosoftAjax.js"></script>
<script src="https://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.7.2.min.js"></script>
<script>
// Load the required SharePoint libraries.
$(function () {
var ctx = null;
var collListItem = null;
// Function to retrieve a query string value.
// For production purposes you may want to use
// a library to handle the query string.
function getQueryStringParameter(paramToRetrieve) {
var params =
document.URL.split("?")[1].split("&");
var strParams = "";
for (var i = 0; i < params.length; i = i + 1) {
var singleParam = params[i].split("=");
if (singleParam[0] == paramToRetrieve)
return singleParam[1];
}
}
// Get the URI decoded URLs.
hostweburl = decodeURIComponent(getQueryStringParameter("SPHostUrl"));
// The js files are in a URL in the form: web_url/_layouts/15/resource_file
var scriptbase = hostweburl + "/_layouts/15/";
// Load the js files and continue to the execOperation function.
$.getScript(scriptbase + "SP.Runtime.js",
function () {
$.getScript(scriptbase + "SP.js", mainFunction);
}
);
var siteUrl = "https://company.sharepoint.com/sites/theSite";
var docSetUrl = "https://company.sharepoint.com/sites/theSite/docLibraryName/docSetName";
var ctx = null;
var files = null;
function mainFunction() {
getFiles(docSetUrl);
}
function getFiles(folderUrl) {
ctx = new SP.ClientContext(siteUrl);
files = ctx.get_web().getFolderByServerRelativeUrl(folderUrl).get_files();
ctx.load(files);
ctx.executeQueryAsync(success, error);
}
function success() {
console.log("success");
for (var i = 0; i < files.get_count(); i++) {
var file = files.get_item(i);
console.log(file.get_name());
}
}
function error(sender, args) {
console.log("error");
console.log(args.get_message());
}
});
</script>
答案 0 :(得分:0)
您需要添加ListItemAllFields属性。
从this answer复制:
using (ClientContext spClientContext = new ClientContext("http://whatever"))
{
var rootweb = spClientContext.Web;
FolderCollection folderCollection =
rootweb.GetFolderByServerRelativeUrl("/Shared Documents/test2").Folders;
// Don't just load the folder collection, but the property on each folder too
spClientContext.Load(folderCollection, fs => fs.Include(f => f.ListItemAllFields));
// Actually fetch the data
spClientContext.ExecuteQuery();
foreach (Folder folder in folderCollection)
{
// This property is now populated
var item = folder.ListItemAllFields;
// This is where the dates you want are stored
var created = (DateTime)item["Created"];
var modified = (DateTime)item["Modified"];
}
}
答案 1 :(得分:0)
关于
我怀疑我需要将Include参数传递给.load()方法
没错,要检索与ListItem
关联的File
属性,您需要通过SP.ClientContext.load
method指定以下表达式'Include(ListItemAllFields)'
,例如:
ctx.load(files,'Include(ListItemAllFields)');
示例
function getFiles(folderUrl) {
var ctx = new SP.ClientContext(siteUrl);
var files = ctx.get_web().getFolderByServerRelativeUrl(folderUrl).get_files();
ctx.load(files,'Include(Name,ListItemAllFields)');
ctx.executeQueryAsync(()=>{
files.get_data().forEach(file =>{
console.log(file.get_name()); //print file name
console.log(file.get_listItemAllFields().get_fieldValues()); //print list item properties
})
},logError);
}
function logError(sender, args) {
console.log(args.get_message());
}