FieldListNum
Contents
[
Hide
]FieldListNum class
Implements the LISTNUM field.
To learn more, visit the Working with Fields documentation article.
public class FieldListNum : Field
Constructors
| Name | Description | 
|---|---|
| FieldListNum() | The default constructor. | 
Properties
| Name | Description | 
|---|---|
| DisplayResult { get; } | Gets the text that represents the displayed field result. | 
| End { get; } | Gets the node that represents the field end. | 
| Format { get; } | Gets a FieldFormatobject that provides typed access to field’s formatting. | 
| HasListName { get; } | Returns a value indicating whether the name of an abstract numbering definition is provided by the field’s code. | 
| IsDirty { get; set; } | Gets or sets whether the current result of the field is no longer correct (stale) due to other modifications made to the document. | 
| IsLocked { get; set; } | Gets or sets whether the field is locked (should not recalculate its result). | 
| ListLevel { get; set; } | Gets or sets the level in the list, overriding the default behavior of the field. | 
| ListName { get; set; } | Gets or sets the name of the abstract numbering definition used for the numbering. | 
| LocaleId { get; set; } | Gets or sets the LCID of the field. | 
| Result { get; set; } | Gets or sets text that is between the field separator and field end. | 
| Separator { get; } | Gets the node that represents the field separator. Can be null. | 
| Start { get; } | Gets the node that represents the start of the field. | 
| StartingNumber { get; set; } | Gets or sets the starting value for this field. | 
| virtual Type { get; } | Gets the Microsoft Word field type. | 
Methods
| Name | Description | 
|---|---|
| GetFieldCode() | Returns text between field start and field separator (or field end if there is no separator). Both field code and field result of child fields are included. | 
| GetFieldCode(bool) | Returns text between field start and field separator (or field end if there is no separator). | 
| override Remove() | |
| Unlink() | Performs the field unlink. | 
| Update() | Performs the field update. Throws if the field is being updated already. | 
| Update(bool) | Performs a field update. Throws if the field is being updated already. | 
Examples
Shows how to number paragraphs with LISTNUM fields.
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// LISTNUM fields display a number that increments at each LISTNUM field.
// These fields also have a variety of options that allow us to use them to emulate numbered lists.
FieldListNum field = (FieldListNum)builder.InsertField(FieldType.FieldListNum, true);
// Lists start counting at 1 by default, but we can set this number to a different value, such as 0.
// This field will display "0)".
field.StartingNumber = "0";
builder.Writeln("Paragraph 1");
Assert.That(field.GetFieldCode(), Is.EqualTo(" LISTNUM  \\s 0"));
// LISTNUM fields maintain separate counts for each list level. 
// Inserting a LISTNUM field in the same paragraph as another LISTNUM field
// increases the list level instead of the count.
// The next field will continue the count we started above and display a value of "1" at list level 1.
builder.InsertField(FieldType.FieldListNum, true);
// This field will start a count at list level 2. It will display a value of "1".
builder.InsertField(FieldType.FieldListNum, true);
// This field will start a count at list level 3. It will display a value of "1".
// Different list levels have different formatting,
// so these fields combined will display a value of "1)a)i)".
builder.InsertField(FieldType.FieldListNum, true);
builder.Writeln("Paragraph 2");
// The next LISTNUM field that we insert will continue the count at the list level
// that the previous LISTNUM field was on.
// We can use the "ListLevel" property to jump to a different list level.
// If this LISTNUM field stayed on list level 3, it would display "ii)",
// but, since we have moved it to list level 2, it carries on the count at that level and displays "b)".
field = (FieldListNum)builder.InsertField(FieldType.FieldListNum, true);
field.ListLevel = "2";
builder.Writeln("Paragraph 3");
Assert.That(field.GetFieldCode(), Is.EqualTo(" LISTNUM  \\l 2"));
// We can set the ListName property to get the field to emulate a different AUTONUM field type.
// "NumberDefault" emulates AUTONUM, "OutlineDefault" emulates AUTONUMOUT,
// and "LegalDefault" emulates AUTONUMLGL fields.
// The "OutlineDefault" list name with 1 as the starting number will result in displaying "I.".
field = (FieldListNum)builder.InsertField(FieldType.FieldListNum, true);
field.StartingNumber = "1";
field.ListName = "OutlineDefault";
builder.Writeln("Paragraph 4");
Assert.That(field.HasListName, Is.True);
Assert.That(field.GetFieldCode(), Is.EqualTo(" LISTNUM  OutlineDefault \\s 1"));
// The ListName does not carry over from the previous field, so we will need to set it for each new field.
// This field continues the count with the different list name and displays "II.".
field = (FieldListNum)builder.InsertField(FieldType.FieldListNum, true);
field.ListName = "OutlineDefault";
builder.Writeln("Paragraph 5");
doc.UpdateFields();
doc.Save(ArtifactsDir + "Field.LISTNUM.docx");
See Also
- class Field
- namespace Aspose.Words.Fields
- assembly Aspose.Words