+ Reply to Thread
Results 1 to 2 of 2

make vba code for multiple comboboxes

Hybrid View

  1. #1
    Registered User
    Join Date
    10-07-2009
    Location
    Arizona
    MS-Off Ver
    Excel 2007
    Posts
    19

    make vba code for multiple comboboxes

    Could anyone suggest how I might simplify the following. I have many comboboxes in a worksheet and I want it so that when someone is in the combobox and they press "enter" then you move to the next cell. Right now I make a vba code for each combobox and I know theres a simple way to cycle through them. Take a look at the code and let me know what you think.
    Thanks!
    Private Sub ComboBox1_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
       If KeyCode = 13 Or KeyCode = 9 Or KeyCode = 39 Then
           Range("C5").Activate
       End If
    End Sub
    Private Sub ComboBox2_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
        If KeyCode = 13 Or KeyCode = 9 Or KeyCode = 39 Then
           Range("C6").Activate
       End If
    End Sub
    Private Sub ComboBox3_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
        If KeyCode = 13 Or KeyCode = 9 Or KeyCode = 39 Then
           Range("C7").Activate
       End If
    End Sub
    Private Sub ComboBox4_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
       If KeyCode = 13 Or KeyCode = 9 Or KeyCode = 39 Then
           Range("C8").Activate
       End If
    End Sub
    Private Sub ComboBox5_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
       If KeyCode = 13 Or KeyCode = 9 Or KeyCode = 39 Then
           Range("C9").Activate
       End If
    End Sub
    This goes on until ComboBox 41.

  2. #2
    Forum Moderator Leith Ross's Avatar
    Join Date
    01-15-2005
    Location
    San Francisco, Ca
    MS-Off Ver
    2000, 2003, & 2010
    Posts
    23,259

    Re: make vba code for multiple comboboxes

    Hello Davo,

    Are these ComboBoxes on a worksheet or a VBA UserForm? I am guessing worksheet. Add the code below to a VBA module in your workbook.
    Sub SelectCell(ByVal ComboBox_Number As Integer, ByVal KeyCode As Integer)
        If KeyCode = 13 Or KeyCode = 9 Or KeyCode = 39 Then
           Cells(ComboBox_Number + 4, "C").Activate
        End If
    End Sub

    Call the macro from each ComboBox_KeyUp event like this...
    Private Sub ComboBox1_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
        Call SelectCell(1, KeyCode)
    End Sub
    
    Private Sub ComboBox2_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
        Call SelectCell(2, KeyCode)
    End Sub
    Sincerely,
    Leith Ross

    Remember To Do the Following....

    1. Use code tags. Place [CODE] before the first line of code and [/CODE] after the last line of code.
    2. Thank those who have helped you by clicking the Star below the post.
    3. Please mark your post [SOLVED] if it has been answered satisfactorily.


    Old Scottish Proverb...
    Luathaid gu deanamh maille! (Rushing causes delays!)

+ Reply to Thread

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Search Engine Friendly URLs by vBSEO 3.6.0 RC 1