SharePoint Online CSOM站点列默认值

时间:2016-09-22 08:55:02

标签: c# sharepoint sharepoint-online csom

在SharePoint Online中,我在使用CSOM(C#)设置网站托管元数据列默认值时遇到问题。为简洁起见,我的代码中没有包含异常处理。这就是我所拥有的:

// Code snippet for what I'm trying to achieve
using (ClientContext ctx = NewCtx(SiteInfo.Url)) // NewCtx is just a static member I use to return a ClientContext object
{
  Field taxColumn = (Field)ctx.Web.Fields.GetByTitle("myMMColumnName");
  ctx.Load(taxColumn);
  ctx.ExecuteQuery();
  TaxonomyFieldValue termField = new TaxonomyFieldValue();
  termField.Label = "My MM Term";
  termField.TermGuid = "b269aef7-6f47-4b02-bf80-7edfb7166a30";
  termField.WssId = -1;
  taxColumn.DefaultValue = value;
  // Place holder for added code (see below)
  taxColumn.Update();
  ctx.Load(taxColumn);
  ctx.ExecuteQuery();
}

该值显示在“站点列”下的UI中,但在TaxonomyHiddenList中没有创建关联项,这是有道理的,因为将查找WssId设置为" -1"没有解决,因此,默认值没有查找,并在列表和库级列中显示为空。

我发现的最接近的解决方案是一篇文章(尽管不是CSOM并在下面链接)建议创建一个"虚拟"列表项(针对消耗MM列的列表)。这将触发在TaxonomyHiddenList中创建项目,但文章建议不要提交" dummy"项目创建。我也试过这个,但似乎没有效果。这是我添加到上一代码块中提到的占位符的代码:

List myList = ctx.Web.Lists.GetByTitle("My List");
ctx.Load(myList);
ctx.ExecuteQuery();
TaxonomyField taxField = ctx.CastTo<TaxonomyField>(myList.Fields.GetByTitle("myMMColumnName"));
ListItemCreationInformation newItemInfo = new ListItemCreationInformation();
ListItem newItem = myList.AddItem(newItemInfo);
newItem["myMMColumnName"] = termField;
taxField.SetFieldValueByValue(newItem, termField);

本文使用.SetFieldValue方法,该方法在CSOM中不可用,因此我可能错误地认为.SetFieldValueByValue具有可比性。

感谢阅读!

参考文献: 文章 - http://sharepointificate.blogspot.com/2014/04/setting-managed-metadata-column-default.html

1 个答案:

答案 0 :(得分:2)

SetFieldValue Method属于TaxonomyField类,表示行:

Field taxColumn = (Field)ctx.Web.Fields.GetByTitle(taxFieldTitle);

需要替换为:

var taxColumn = ctx.CastTo<TaxonomyField>(ctx.Web.Fields.GetByTitle(taxFieldTitle));

TaxonomyField taxColumn = ctx.CastTo<TaxonomyField>(ctx.Web.Fields.GetByTitle(taxFieldTitle));

初始化TaxonomyField后,可以设置默认值,如下所示:

//get taxonomy field
var taxColumn = ctx.CastTo<TaxonomyField>(ctx.Web.Fields.GetByTitle(taxFieldTitle));
ctx.Load(taxColumn);
ctx.ExecuteQuery();
//initialize taxonomy field value
var defaultValue = new TaxonomyFieldValue();
defaultValue.WssId = -1;
defaultValue.Label = termLabel;
defaultValue.TermGuid = termId.ToString();
//retrieve validated taxonomy field value
var validatedValue = taxColumn.GetValidatedString(defaultValue);
ctx.ExecuteQuery();
//set default value for a taxonomy field
taxColumn.DefaultValue = validatedValue.Value;
taxColumn.Update();
ctx.ExecuteQuery();
  

注意:TaxonomyField.GetValidatedString method用于   分类法字段值的验证,其又包括   解析WssId

更新

使用Field.UpdateAndPushChanges method将更改传播到使用该字段的所有列表

所以,替换:

taxColumn.Update();
ctx.ExecuteQuery();

使用:

taxColumn.UpdateAndPushChanges(true);
ctx.ExecuteQuery();