当前位置: 首页>>代码示例>>C#>>正文


C# SPFieldCollection.Add方法代码示例

本文整理汇总了C#中SPFieldCollection.Add方法的典型用法代码示例。如果您正苦于以下问题:C# SPFieldCollection.Add方法的具体用法?C# SPFieldCollection.Add怎么用?C# SPFieldCollection.Add使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SPFieldCollection的用法示例。


在下文中一共展示了SPFieldCollection.Add方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: AddFieldTo

        protected virtual void AddFieldTo(SPFieldCollection fieldCollection, Action<SPField> fieldAction)
        {
            SPField newField = null;
            if (ID != System.Guid.Empty && fieldCollection.Web.AvailableFields.Contains(ID))
            {
                SPField field = fieldCollection.Web.AvailableFields[ID];
                fieldCollection.Add(field);
                newField = fieldCollection[ID];
            }
            else
                newField = CreateField(fieldCollection);

            if (fieldAction != null)
                fieldAction(newField);

            if (!string.IsNullOrEmpty(Title))
                newField.Title = Title;

            if (!string.IsNullOrEmpty(Description))
                newField.Description = Description;

            newField.Update();
        }
开发者ID:TypesInCode,项目名称:J.SharePoint,代码行数:23,代码来源:SPFieldMetadata.cs

示例2: InnerEnsureField

        private SPField InnerEnsureField(SPFieldCollection fieldCollection, BaseFieldInfo fieldInfo)
        {
            SPField field = null;

            if (fieldInfo.GetType().Name.StartsWith("MinimalFieldInfo", StringComparison.OrdinalIgnoreCase))
            {
                // Ensuring a MinimalFieldInfo from its SchemaXML is impossible since the MinimalFieldInfo object
                // doesn't hold enough information to completely describe the field metadata.
                // Instead, we have to re-use the site column and apply it to the list.
                var existingSiteColumn = fieldCollection.Web.Site.RootWeb.Fields.TryGetFieldByStaticName(fieldInfo.InternalName);

                if (existingSiteColumn == null)
                {
                    throw new NotSupportedException(
                        string.Format(
                            CultureInfo.InvariantCulture,
                            "Failed to ensure MinimalFieldInfo for field {0} because the pre-requisite Site Column doesn't exist.",
                            fieldInfo.InternalName));
                }

                SPList parentList = null;
                if (!TryGetListFromFieldCollection(fieldCollection, out parentList))
                {
                    throw new NotSupportedException(
                        string.Format(
                            CultureInfo.InvariantCulture,
                            "Failed to ensure MinimalFieldInfo for field {0}. A MinimalFieldInfo can only be used to ensure a Field on a List's SPFieldCollection, not to re-define an OOTB site column definition.",
                            fieldInfo.InternalName));
                }

                fieldCollection.Add(existingSiteColumn);

                field = fieldCollection[existingSiteColumn.Id];
            }
            else
            {
                // We have a fully-functional/fully-detailed IFieldInfo which should support a conversion to SchemaXML: go ahead and try to add the field.
                XElement xmlSchemaForField = this.fieldSchemaHelper.SchemaForField(fieldInfo);
                field = this.fieldSchemaHelper.EnsureFieldFromSchema(fieldCollection, xmlSchemaForField);
            }

            // In some cases, the returned field will not match the one we meant to create or ensure. For example,
            // we may have defined a fieldInfo with an InternalName that clashes with an already existing field.
            // In such a case, EnsureFieldFromSchema will return us the conflicting/already existing field (not
            // the one we mean to ensure).
            if (field.Id == fieldInfo.Id && field.InternalName == fieldInfo.InternalName)
            {
                try
                {
                    var refetchedField = fieldCollection[field.Id];
                }
                catch (ArgumentException)
                {
                    // in a sneaky edge case, we're dealing with a sub-web's fieldCollection,
                    // and we actually ensured the column on the root web (instead of on the sub-web).
                    fieldCollection = fieldCollection.Web.Site.RootWeb.Fields;
                }

                // Set the field visibility
                this.UpdateFieldVisibility(field, fieldInfo);

                // Set miscellaneous properties
                this.UpdateFieldTypeSpecificProperties(fieldCollection, field, fieldInfo);

                // Tiny bit of ugly reflection here: we assume that all implementations of IFieldInfo will
                // derive from FieldInfo<T>, which in turn lets us assume a DefaultValue property will always
                // be there for us to create our FieldValueInfo (which simply needs an untyped object as value).
                FieldValueInfo defaultValueFieldInfo = new FieldValueInfo(fieldInfo, fieldInfo.GetType().GetProperty("DefaultValue").GetValue(fieldInfo));
                this.fieldValueWriter.WriteValueToFieldDefault(fieldCollection, defaultValueFieldInfo);

                if (!string.IsNullOrEmpty(fieldInfo.DefaultFormula))
                {
                    if (!string.IsNullOrEmpty(field.DefaultValue))
                    {
                        // A default value was already specified, so setting a Formula makes no sense.
                        throw new InvalidOperationException("Failed to ensure field " + fieldInfo.InternalName + " in its entirety because both DefaultFormula and DefaultValue properties were specified. Please only set Formula OR DefaultValue, not both. Also don't forget to clean up the partially created field " + fieldInfo.InternalName + ".");
                    }

                    // Setting the DefaultFormula through the SchemaXML doesn't work,
                    // so let's force it here.
                    field.DefaultFormula = fieldInfo.DefaultFormula;
                }

                field.Update();
            }

            return field;
        }
开发者ID:ASAGARG,项目名称:Dynamite,代码行数:88,代码来源:FieldHelper.cs

示例3: EnsureFieldFromSchema

        /// <summary>
        /// Adds a field defined in xml to a collection of fields.
        /// </summary>
        /// <param name="fieldCollection">The SPField collection.</param>
        /// <param name="fieldXml">The field XML schema.</param>
        /// <returns>
        /// A string that contains the internal name of the new field.
        /// </returns>
        /// <exception cref="System.ArgumentNullException">
        /// fieldCollection
        /// or
        /// fieldXml
        /// </exception>
        /// <exception cref="System.FormatException">Invalid xml.</exception>
        public SPField EnsureFieldFromSchema(SPFieldCollection fieldCollection, XElement fieldXml)
        {
            if (fieldCollection == null)
            {
                throw new ArgumentNullException("fieldCollection");
            }

            if (fieldXml == null)
            {
                throw new ArgumentNullException("fieldXml");
            }

            // Gotta use reflection to figure out if the field collection comes from
            // a content type (and thus should be read-only)
            bool isContentTypeFieldCollection = (bool)typeof(SPFieldCollection)
                    .GetField("m_FromContentType", BindingFlags.NonPublic | BindingFlags.Instance)
                    .GetValue(fieldCollection);
            if (isContentTypeFieldCollection)
            {
                throw new ArgumentException("EnsureField - Impossible to ensure field on Content Type's field collection - it should be considered as read-only. Use IContentTypeHelper.EnsureContentType instead (which will update the content type's FieldRefs collection).");
            }

            this.logger.Info("Start method 'EnsureField'");

            Guid id = Guid.Empty;
            string displayName = string.Empty;
            string internalName = string.Empty;
            string typeName = string.Empty;

            // Validate the xml of the field and get its properties
            if (this.IsFieldXmlValid(fieldXml, out id, out displayName, out internalName, out typeName))
            {
                // If its a lookup we need to fix up the xml.
                if (this.IsLookup(fieldXml))
                {
                    fieldXml = this.FixLookupFieldXml(fieldCollection.Web, fieldXml);
                }

                // Check if the field already exists. Skip the creation if so.
                if (!this.FieldExists(fieldCollection, internalName, id))
                {
                    // We want to create the field: if we're trying to add field on a list field collection,
                    // then chances are the field is already defined on the parent root web (we actually enforce
                    // this in the calling FieldHelper). In such a case, we need to re-use the existing field definition,
                    // because using .AddFieldAsXml directly on the list field collection would cause a field
                    // with an InternalName==ParentRootWebFieldDisplayName (weird bug, really - using AddFieldAsXml
                    // on a list's SPFieldCollection is just a bad idea: use the already provisioned site column
                    // whenever possible).
                    string addedInternalName = string.Empty;
                    SPField parentRootWebExistingField = null;
                    SPWeb rootWeb = fieldCollection.Web.Site.RootWeb;
                    SPFieldCollection rootWebFields = rootWeb.Fields;
                    if (!this.FieldExists(rootWebFields, internalName, id))
                    {
                        if (fieldCollection.List == null && fieldCollection.Web.ID == rootWeb.ID)
                        {
                            rootWebFields = fieldCollection;
                        }

                        // Add on Root Web if it wasn't done before
                        addedInternalName = rootWebFields.AddFieldAsXml(fieldXml.ToString(), false, SPAddFieldOptions.Default);
                    }

                    // Re-use the parent field definition
                    parentRootWebExistingField = rootWebFields[id];

                    // Make sure we're adding the field on a List or on a different web than the root web:
                    // we don't want to ensure the field twice on the root web
                    if (fieldCollection.List != null)
                    {
                        if (parentRootWebExistingField.EnforceUniqueValues)
                        {
                            // Before we ensure the site column on a list, gotta make sure
                            // that, on a list, EnforceUniqueValues=TRUE IF-AND-ONLY-IF Indexed=TRUE
                            parentRootWebExistingField.Indexed = true;
                        }

                        addedInternalName = fieldCollection.Add(parentRootWebExistingField);

                        // Then update the list column with the new list-specific or web-specfic definition
                        var createdField = this.fieldLocator.GetFieldById(fieldCollection, id);
                        createdField.SchemaXml = fieldXml.ToString();   // TODO: we should probably do a more granular update (property by property,
                                                                        // only when needed) instead of brutally overwriting the schema XML like this.
                        createdField.Update();
                    }
                    else if (fieldCollection.Web.ID != rootWeb.ID)
//.........这里部分代码省略.........
开发者ID:ASAGARG,项目名称:Dynamite,代码行数:101,代码来源:FieldSchemaHelper.cs

示例4: CreateField

 protected virtual SPField CreateField(SPFieldCollection fieldCollection)
 {
     fieldCollection.Add(Name, Type, Required);
     return fieldCollection[Name];
 }
开发者ID:TypesInCode,项目名称:J.SharePoint,代码行数:5,代码来源:SPFieldMetadata.cs

示例5: AddField

 public string AddField(SPFieldCollection fieldCollection, SPField field)
 {
     return fieldCollection.Add(field);
 }
开发者ID:powareverb,项目名称:spgenesis,代码行数:4,代码来源:SPGENFieldStorage.cs


注:本文中的SPFieldCollection.Add方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。