Compartilhar via


Evento WorkbookBase.BeforeClose

Ocorre antes da pasta de trabalho fechar. Se a pasta de trabalho foi alterada, esse evento ocorre antes que o usuário foi solicitado a salvar as alterações.

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

Sintaxe

'Declaração
Public Event BeforeClose As WorkbookEvents_BeforeCloseEventHandler
public event WorkbookEvents_BeforeCloseEventHandler BeforeClose

Exemplos

O exemplo de código a seguir demonstra um manipulador para o evento de BeforeClose . O manipulador de eventos solicita ao usuário para salvar as alterações, não alterações de salvar, ou cancela a operação próximo se as alterações foram feitas para a pasta de trabalho como era a exceto o último. Se o usuário não salvar as alterações, então a propriedade de Saved de pasta de trabalho é definida como true de modo que o Microsoft Office Excel não solicita ao usuário para salvar a pasta de trabalho quando a próxima operação continua. Se o usuário cancelou a operação próximo, então o parâmetro de Cancel do manipulador de eventos WorkbookEvents_BeforeCloseEventHandler é definido como true de modo que o Microsoft Office Excel não fecha a pasta de trabalho.

Este exemplo destina-se a uma personalização no nível de documento.

Sub ThisWorkbook_BeforeClose(ByRef Cancel As Boolean) _
    Handles Me.BeforeClose

    If Not Me.Saved Then
        Dim result As DialogResult = _
            MessageBox.Show("Do you want to save the " & _
            "changes you made to " & Me.Name & "?", _
            "Example", MessageBoxButtons.YesNoCancel)

        Select Case result
            Case DialogResult.Yes
                Me.Save()
            Case DialogResult.Cancel
                Cancel = True
                ' The following code ensures that the default Save File 
                ' dialog is not displayed.
            Case DialogResult.No
                Me.Saved = True
        End Select
    End If
End Sub
private void WorkbookBeforeClose()
{
    this.BeforeClose +=
        new Excel.WorkbookEvents_BeforeCloseEventHandler(
        ThisWorkbook_BeforeClose);
}

void ThisWorkbook_BeforeClose(ref bool Cancel)
{
    if (!this.Saved)
    {
        DialogResult result = MessageBox.Show("Do you want to save the " +
            "changes you made to " + this.Name + "?", "Example",
            MessageBoxButtons.YesNoCancel);

        switch (result)
        {
            case DialogResult.Yes:
                this.Save();
                break;

            case DialogResult.Cancel:
                Cancel = true;
                break;

            // The following code ensures that the default Save File 
            // dialog is not displayed.
            case DialogResult.No:
                this.Saved = true;
                break;
        }
    }
}

Segurança do .NET Framework

Consulte também

Referência

WorkbookBase Classe

Namespace Microsoft.Office.Tools.Excel