3

次のコードがあります (プロトタイプのように)

 private void WriteDataToItems(Item rootitem, IQueryable<LanguageData> languageData, SC.Globalization.Language sclng)
        {
            if (rootitem == null)
                return;
            rootitem = IncVersion(rootitem);
            Response.Write(string.Format("Item {0} - {1}<br/>", rootitem.DisplayName, rootitem.Paths.FullPath));
            rootitem.Editing.BeginEdit();
            try
            {
                foreach (Field fld in rootitem.Fields.Where(d => !d.Shared && !d.Name.StartsWith("__") && d.Name.Trim() != ""))
                {
                    Response.Write(string.Format("Processing  fld: - {0}<br/>", fld.ID.Guid.ToString()));
                    var data = languageData.FirstOrDefault(
                            d => (string.Compare(d.FieldName, fld.Name, true) == 0) && (string.Compare(d.ItemID, rootitem.ID.Guid.ToString(), true) == 0));
                    if (data != null)
                    {
                        string newValue = null;
                        switch (sclng.Name)
                        {
                            case "en":
                                newValue = data.En;
                                break;
                            case "nn-NO":
                                newValue = data.nnNO;
                                break;
                            case "sv-SE":
                                newValue = data.svSE;
                                break;
                            case "da-DK":
                                newValue = data.DaDK;
                                break;
                            case "de-DE":
                                newValue = data.deDE;
                                break;
                            default:
                                newValue = null;
                                break;
                        }

                        if (newValue != null)
                        {
                            Response.Write(string.Format("Save field with Id:{0} New Value:{1}<br/>", fld.ID.Guid, newValue));
                            fld.Value = newValue;
                        }
                    }

                }

                rootitem.Editing.EndEdit();
            }
            catch (Exception ex)
            {
                rootitem.Editing.CancelEdit();

            }

            foreach (Item cd in rootitem.GetChildren())
            {
                WriteDataToItems(cd, languageData, sclng);
            }

        }

そして、rootitem.Fieldsオブジェクトにテンプレートに記述されているすべてのフィールドが含まれていないという問題があります。いくつかの値を持つフィールドだけが含まれているが、空のデータを持つフィールドは含まれていないというファイリングがあります。

foreach (Field fld in rootitem.Fields.Where(d => !d.Shared && !d.Name.StartsWith("__") && d.Name.Trim() != ""))

すべてのカスタム フィールド名を取得するにはどうすればよいですか? テンプレートデータを使用する必要がありますか?

4

3 に答える 3

3

使用した後Fields.ReadAll()、これらのフィールドで使用されているメモリをメソッドで解放できますitem.Fields.Reset();

ReadAll()とのコードは次のReset()とおりです。

 /// <summary>
/// Reads all.
/// 
/// </summary>
public void ReadAll()
{
  Template template = TemplateManager.GetTemplate(this._ownerItem);
  if (template == null)
    return;
  TemplateField[] fields = template.GetFields();
  this._fields = new Field[fields.Length];
  for (int index = 0; index < fields.Length; ++index)
    this._fields[index] = new Field(fields[index].ID, this._ownerItem);
}

/// <summary>
/// Resets this instance.
/// 
/// </summary>
public void Reset()
{
  this._fields = (Field[]) null;
  this._innerFields = (FieldList) null;
}
于 2013-06-28T08:28:10.377 に答える