Excel 5.0 Events

The versions of Excel before Excel 97 also supported events although these events had to be explicitly defined.
For compatibility reasons these methods are still supported although they should not be used now.
VBA > Macros > Excel 5.0 Macros.


OnSheetActivate

This event runs whenever the user switches to a sheet in the workbook.
You can set this event for any of the following objects:

' any sheet in the application
Application.OnSheetActivate = "Macro_Name"
'any sheet in the workbook
Workbook.OnSheetActivate = "Macro_Name"
' a specific sheet
Worksheet.OnSheetActivate = "Macro_Name"

These have been replaced with the following events:

Application.SheetActivate 
Workbook.SheetActivate
Worksheet.Activate

OnSheetDeactivate

This event runs after a sheet has been deselected.

' any sheet in the application
Application.OnSheetDeactivate = "Macro_Name"
'any sheet in the workbook
Workbook.OnSheetDeactivate = "Macro_Name"
' a specific sheet
Worksheet.OnSheetDeactivate = "Macro_Name"

Using Activesheet or Activeworkbook in this event can cause unexpected results.
These have been replaced with the following events:

Application.SheetDeactivate 
Workbook.SheetDeactivate
Worksheet.Deactivate

OnWindow

This event runs whenever the user switches to a specific window.

' any sheet in the application
Application.OnWindow = "Macro_Name"
' a specific window is activated
Windows("MyWbk.xls").OnWindow ="Macro_Name"

You can disassociate this event handler by assigning an empty string to the OnWindow property

Application.OnWindow = "" 

These have been replaced with the following events:

Application.WindowActivate 
Workbook.WindowActivate
Worksheet.Activate

The equivalent deactivate events are also available:

Application.WindowDeactivate 
Workbook.WindowDeactivate
Worksheet.Deactivate

OnCalculate

This event runs immediatley after a worksheet is recalculated.

Application.OnCalculate = "Macro_Name" 
Workbook.OnCalculate = "Macro_Name"

You can disassociate this event handler by assigning an empty string to the OnCalculate property

Application.OnCalculate = "" 

These have been replaced with the following events:

Application.SheetCalculate 
Workbook.SheetCalculate
Worksheet.Calculate

OnEntry

This event runs when a user enters some data onto a worksheet.

Application.OnEntry = "Macro_Name" 
Workbook.OnEntry = "Macro_Name"

This event occurs after the user enters the data and presses Enter or selects another cell.
The event will not occur if the user selects (Edit > Cut), (Edit > Paste) or if another procedure changes the contents of the cells.
These have been replaced with the following events:

Application.SheetChange 
Workbook.SheetChange
Worksheet.Change

OnData

This runs when new data arrives from an application other than Excel.

Application.OnData = "Macro_Name" 
Workbook.OnData = "Macro_Name"

This property is also available from some other objects that handle the arrival of data linked through DDE, object linking or embedding.
The OnData event does not run if it is linked to another running instance of Excel.
These have been replaced with the following events:

Application.SheetChange 
Workbook.SheetChange
Worksheet.Change

© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext