UpdateDirtyFields

LoadOptions.UpdateDirtyFields property

Specifica se aggiornare i campi con ilsporco attributo.

public bool UpdateDirtyFields { get; set; }

Esempi

Mostra come utilizzare la proprietà speciale per aggiornare il risultato del campo.

Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);

// Assegna il valore della proprietà "Autore" incorporata nel documento, quindi visualizzalo con un campo.
doc.BuiltInDocumentProperties.Author = "John Doe";
FieldAuthor field = (FieldAuthor)builder.InsertField(FieldType.FieldAuthor, true);

Assert.False(field.IsDirty);
Assert.AreEqual("John Doe", field.Result);

// Aggiorna la proprietà. Il campo mostra ancora il vecchio valore.
doc.BuiltInDocumentProperties.Author = "John & Jane Doe";

Assert.AreEqual("John Doe", field.Result);

// Poiché il valore del campo non è aggiornato, possiamo contrassegnarlo come "sporco".
// Questo valore non sarà aggiornato finché non aggiorneremo il campo manualmente con il metodo Field.Update().
field.IsDirty = true;

using (MemoryStream docStream = new MemoryStream())
{
    // Se salviamo senza chiamare un metodo di aggiornamento,
    // il campo continuerà a visualizzare il valore scaduto nel documento di output.
    doc.Save(docStream, SaveFormat.Docx);

    // L'oggetto LoadOptions ha un'opzione per aggiornare tutti i campi
    // contrassegnato come "sporco" durante il caricamento del documento.
    LoadOptions options = new LoadOptions();
    options.UpdateDirtyFields = updateDirtyFields;
    doc = new Document(docStream, options);

    Assert.AreEqual("John & Jane Doe", doc.BuiltInDocumentProperties.Author);

    field = (FieldAuthor)doc.Range.Fields[0];

    // L'aggiornamento di campi sporchi come questo imposta automaticamente il flag "IsDirty" su false.
    if (updateDirtyFields)
    {
        Assert.AreEqual("John & Jane Doe", field.Result);
        Assert.False(field.IsDirty);
    }
    else
    {
        Assert.AreEqual("John Doe", field.Result);
        Assert.True(field.IsDirty);
    }
}

Guarda anche