Compartilhar via


Enumeração ChangeReason (sistema de 2007)

Fornece o motivo que os dados originais foi restaurados para um ListObject que limite a dados.

Namespace:  Microsoft.Office.Tools.Excel
Assembly:  Microsoft.Office.Tools.Excel.v9.0 (em Microsoft.Office.Tools.Excel.v9.0.dll)

Sintaxe

Public Enumeration ChangeReason

Dim instance As ChangeReason
public enum ChangeReason

Membros

Nome do membro Descrição
ReadOnlyDataSource A fonte de dados que o ListObject o controle está limite é somente leitura.
FixedLengthDataSource A fonte de dados que o ListObject controle está limite não permite adicionar ou remover linhas.
FixedNumberOfColumnsInDataBoundList The ListObject controle não permite colunas a ser adicionada ou removida depois que ele está limite a dados.
DataBoundColumnHeaderIsAutoSet Quando o AutoSetDataBoundColumnHeaders propriedade das ListObject controle estiver definida como true, o ListObject controle não permite ao usuário alterar os cabeçalhos de coluna.
ErrorInCommit Uma alterar nos dados no ListObject não pôde ser comprometida com a fonte de dados que o controle está limite ao controle.
Other Os dados originais restaurados porque uma razão não especificada por qualquer um dos outros ChangeReason valores.

Comentários

Quando o ListObject está limite a dados e o usuário executa uma operação que não é permitida a ListObject Restaura-se ao seu estado anterior e gera o OriginalDataRestored evento. The ChangeReason enumeração fornece informações sobre por que ocorreu a restauração.

Exemplos

O exemplo de código a seguir cria um DataTable e um ListObjecte vincula o ListObject para o DataTable. Em seguida, ele cria um OriginalDataRestored evento manipulador. Para testar o evento, clicar com o botão direito do mouse em uma letra da coluna acima de ListObject na folha 1 e, em seguida, clique em Excluir no menu de atalho.O manipulador de eventos substitui a coluna e dados de cabeçalho de coluna e exibe uma mensagem indicando o tipo de dados foi restaurado e o motivo pelo qual se os dados originais foi restaurados.

Este exemplo é para uma personalização em nível de documento.

WithEvents OriginalDataRestoredList As _
    Microsoft.Office.Tools.Excel.ListObject
PrivateSub ListObject_OriginalDataRestored()
    ' Create a new DataSet and DataTable.Dim ds AsNew DataSet()
    Dim dt As DataTable = ds.Tables.Add("Customers")
    Dim lastName AsNew DataColumn("LastName")
    dt.Columns.Add(lastName)
    dt.Columns.Add(New DataColumn("FirstName"))

    ' Add two new rows to the DataTable.Dim dr1 As DataRow = dt.NewRow()
    dr1("LastName") = "Chan"
    dr1("FirstName") = "Gareth"
    dt.Rows.Add(dr1)
    Dim dr2 As DataRow = dt.NewRow()
    dr2("LastName") = "Nitsche"
    dr2("FirstName") = "Sonja"
    dt.Rows.Add(dr2)

    ' Create a list object.
    OriginalDataRestoredList = Me.Controls.AddListObject( _
        Me.Range("A1"), "OriginalDataRestoredList")

    ' Bind the list object to the DataTable.
    OriginalDataRestoredList.AutoSetDataBoundColumnHeaders = True
    OriginalDataRestoredList.SetDataBinding(ds, "Customers", _
        "LastName", "FirstName")
EndSubPrivateSub List1_OriginalDataRestored(ByVal sender AsObject, _
    ByVal e As Microsoft.Office.Tools.Excel.OriginalDataRestoredEventArgs) _
    Handles OriginalDataRestoredList.OriginalDataRestored
    MessageBox.Show("This data is bound to a data source and " & _
    "will be restored. This change is: " & e.ChangeType.ToString() & _
    ". The reason is: " & e.ChangeReason.ToString() + ".")
EndSub
privatevoid ListObject_OriginalDataRestored()
{
    // Create a new DataSet and DataTable.
    DataSet ds = new DataSet();
    DataTable dt = ds.Tables.Add("Customers");
    DataColumn lastName = new DataColumn("LastName");
    dt.Columns.Add(lastName);
    dt.Columns.Add(new DataColumn("FirstName"));

    // Add two new rows to the DataTable.
    DataRow dr1 = dt.NewRow();
    dr1["LastName"] = "Chan";
    dr1["FirstName"] = "Gareth";
    dt.Rows.Add(dr1);
    DataRow dr2 = dt.NewRow();
    dr2["LastName"] = "Nitsche";
    dr2["FirstName"] = "Sonja";
    dt.Rows.Add(dr2);

    // Create a list object.
    Microsoft.Office.Tools.Excel.ListObject list1 = 
        this.Controls.AddListObject(
        this.Range["A1", missing], "list1");

    // Bind the list object to the DataTable.
    list1.AutoSetDataBoundColumnHeaders = true;
    list1.SetDataBinding(ds, "Customers", "LastName",
        "FirstName");

    // Create the event handler.
    list1.OriginalDataRestored += new 
        Microsoft.Office.Tools.Excel.
        OriginalDataRestoredEventHandler(list1_OriginalDataRestored);
}

void list1_OriginalDataRestored(object sender, 
    Microsoft.Office.Tools.Excel.OriginalDataRestoredEventArgs e)
{
    MessageBox.Show("This data is bound to a data source and " +
    "will be restored. This change is: " + e.ChangeType.ToString() +
    ". The reason is: " + e.ChangeReason.ToString() + ".");
}

Consulte também

Referência

Namespace Microsoft.Office.Tools.Excel