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() + ".");
}