Suppress Worksheet_Activate event

tiredofit

Well-known Member
Joined
Apr 11, 2013
Messages
1,832
Office Version
  1. 365
  2. 2019
Platform
  1. Windows
My workbook contains Sheet1 and Sheet2.

The code in Sheet1 is as follows:

Code:
Option Explicit

Private Sub Worksheet_Activate()

    MsgBox "hi"
 
End Sub

and in Sheet2:

Code:
Option Explicit

Private Sub Worksheet_Deactivate()

    Application.EnableEvents = False
 
    Me.Activate
 
    Application.EnableEvents = True
 
End Sub

I am trying to prevent users moving away from Sheet2.

When I'm on Sheet2, I click on Sheet1 and the Worksheet_Deactivate kicks off.

When Me.Activate is run, Sheet2 is active.

After Application.EnableEvents = True is run, Sub Worksheet_Activate on Sheet1 gets trigged.

How can I prevent Worksheet_Activate from running?

Thanks
 

Excel Facts

Format cells as time
Select range and press Ctrl+Shift+2 to format cells as time. (Shift 2 is the @ sign).
Why do you have an Activate event in a sheet that is never supposed to be activated?
 
Upvote 0
Why do you have an Activate event in a sheet that is never supposed to be activated?
The reason is Sheet2 needs to check for some conditions.

If the conditions are OK, then the user can navigate off it, otherwise, stay there.

I suppose I could add a public variable.

If the condition is met, then allow, otherwise prevent from leaving Sheet2.

In Sheet1, check for this variable's value?
 
Upvote 0
Yes, that should do it.
 
Upvote 0

Forum statistics

Threads
1,214,858
Messages
6,121,956
Members
449,057
Latest member
FreeCricketId

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top