VisitFieldStart
Contenuti
[
Nascondere
]DocumentVisitor.VisitFieldStart method
Chiamato quando inizia un campo nel documento.
public virtual VisitorAction VisitFieldStart(FieldStart fieldStart)
Parametro | Tipo | Descrizione |
---|---|---|
fieldStart | FieldStart | L’oggetto che viene visitato. |
Valore di ritorno
UNVisitorAction
valore che specifica come continuare l’enumerazione.
Osservazioni
Un campo in un documento di Word è costituito da un codice di campo e da un valore di campo.
Ad esempio, un campo che visualizza un numero di pagina può essere rappresentato come segue:
[Inizio Campo]PAGINA[Separatore Campo]98[Fine Campo]
Il separatore di campo separa il codice di campo dal valore di campo nel documento. Tieni presente che alcuni campi hanno solo codice di campo e non hanno separatore di campo e valore di campo.
I campi possono essere nidificati.
Esempi
Mostra come stampare la struttura dei nodi di ogni campo in un documento.
public void FieldToText()
{
Document doc = new Document(MyDir + "DocumentVisitor-compatible features.docx");
FieldStructurePrinter visitor = new FieldStructurePrinter();
// Quando facciamo in modo che un nodo composito accetti un visitatore del documento, il visitatore visita il nodo accettante,
// e poi attraversa tutti i figli del nodo in modo approfondito.
// Il visitatore può leggere e modificare ogni nodo visitato.
doc.Accept(visitor);
Console.WriteLine(visitor.GetText());
}
/// <summary>
/// Attraversa l'albero non binario dei nodi figlio di un nodo.
/// Crea una mappa sotto forma di una stringa di tutti i nodi Campo incontrati e dei loro figli.
/// </summary>
public class FieldStructurePrinter : DocumentVisitor
{
public FieldStructurePrinter()
{
mBuilder = new StringBuilder();
mVisitorIsInsideField = false;
}
public string GetText()
{
return mBuilder.ToString();
}
/// <summary>
/// Chiamato quando nel documento viene incontrato un nodo Esegui.
/// </summary>
public override VisitorAction VisitRun(Run run)
{
if (mVisitorIsInsideField) IndentAndAppendLine("[Run] \"" + run.GetText() + "\"");
return VisitorAction.Continue;
}
/// <summary>
/// Chiamato quando nel documento viene incontrato un nodo FieldStart.
/// </summary>
public override VisitorAction VisitFieldStart(FieldStart fieldStart)
{
IndentAndAppendLine("[Field start] FieldType: " + fieldStart.FieldType);
mDocTraversalDepth++;
mVisitorIsInsideField = true;
return VisitorAction.Continue;
}
/// <summary>
/// Chiamato quando nel documento viene incontrato un nodo FieldEnd.
/// </summary>
public override VisitorAction VisitFieldEnd(FieldEnd fieldEnd)
{
mDocTraversalDepth--;
IndentAndAppendLine("[Field end]");
mVisitorIsInsideField = false;
return VisitorAction.Continue;
}
/// <summary>
/// Chiamato quando nel documento viene incontrato un nodo FieldSeparator.
/// </summary>
public override VisitorAction VisitFieldSeparator(FieldSeparator fieldSeparator)
{
IndentAndAppendLine("[FieldSeparator]");
return VisitorAction.Continue;
}
/// <summary>
/// Aggiungi una riga a StringBuilder e applica un rientro a seconda della profondità del visitatore
/// nell'albero dei nodi secondari del campo.
/// </summary>
/// <param name="text"></param>
private void IndentAndAppendLine(string text)
{
for (int i = 0; i < mDocTraversalDepth; i++)
{
mBuilder.Append("| ");
}
mBuilder.AppendLine(text);
}
private bool mVisitorIsInsideField;
private int mDocTraversalDepth;
private readonly StringBuilder mBuilder;
}
Guarda anche
- enum VisitorAction
- class FieldStart
- class DocumentVisitor
- spazio dei nomi Aspose.Words
- assemblea Aspose.Words