Page 1 of 1

สร้างDropDownlist&ComboBox

Posted: Tue Jul 30, 2013 3:57 pm
by pongpang
การทำลีส ถ้าหากข้อมูลที่ทำลีสไว้ใน sheet1(ชีทเดียวกับลีส) สามารถพิมพ์ตัวอักษรตัวแรกของคำแล้วจะมีตัวอักษรมาต่อท้าย แต่เมื่อนำข้อมูลไปไว้ที่ sheet2 เมื่อพิมพ์ตัวอักษรตัวแรกของคำไม่ไม่มีตัวอักษรมาต่อท้าย
จะต้องปรับปรุง Code อย่างไร จึงจะทำให้เมื่อเก็บข้อมูลที่ชีท 2 แล้ว ลีสที่ชีท 1 สามารถพิมพ์ตัวอักษรตัวแรกของคำแล้วมีตัวอักษรมาต่อท้าย ครับ ดังตัวอย่างในไฟล์ที่แนบ

Code: Select all

Private Sub TempCombo_KeyDown(ByVal _
        KeyCode As MSForms.ReturnInteger, _
        ByVal Shift As Integer)
    'Hide combo box and move to next cell on Enter and Tab
    Select Case KeyCode
        Case 9
            ActiveCell.Offset(0, 1).Activate
        Case 13
            ActiveCell.Offset(1, 0).Activate
        Case Else
            'do nothing
    End Select

End Sub

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim str As String
Dim cboTemp As OLEObject
Dim ws As Worksheet
Set ws = ActiveSheet
  On Error GoTo errHandler

If Target.Count > 1 Then GoTo exitHandler

  Set cboTemp = ws.OLEObjects("ComboBox1")
    On Error Resume Next
  If cboTemp.Visible = True Then
    With cboTemp
      .Top = 10
      .Left = 10
      .ListFillRange = ""
      .LinkedCell = ""
      .Visible = False
      .Value = ""
    End With
  End If

  On Error GoTo errHandler
  If Target.Validation.Type = 3 Then
    Application.EnableEvents = False
    str = Target.Validation.Formula1
    str = Right(str, Len(str) - 1)
    With cboTemp
      .Visible = True
      .Left = Target.Left
      .Top = Target.Top
      .Width = Target.Width + 15
      .Height = Target.Height + 5
      .ListFillRange = ws.Range(str).Address
      .LinkedCell = Target.Address
    End With
    cboTemp.Activate
  End If

exitHandler:
  Application.EnableEvents = True
  Application.ScreenUpdating = True
  Exit Sub
errHandler:
  Resume exitHandler

End Sub
หวังว่าคงได้รับความกรุณา ครับ

Re: สร้างDropDownlist&ComboBox

Posted: Tue Jul 30, 2013 4:11 pm
by snasui
:D ใน Sheet2 มี Code เหมือน Sheet1 มี ComboBox1 ในชีท 2 หรือไม่ครับ

Re: สร้างDropDownlist&ComboBox

Posted: Tue Jul 30, 2013 4:42 pm
by pongpang
ขอบคุณมากครับ ไม่มี ComboBox ใน sheet2 ครับ และไม่มี Code ที่ sheet2 ครับ

Re: สร้างDropDownlist&ComboBox

Posted: Tue Jul 30, 2013 5:19 pm
by snasui
:D ไม่มีก็ไม่แสดงผลครับ

Re: สร้างDropDownlist&ComboBox

Posted: Tue Jul 30, 2013 5:23 pm
by pongpang
ขอบคุณมากครับ
ความต้องการ คือ ไว้ลีส ที่ชีทที่ 1 ข้อมูล เก็บในชีทที่ 2 จะต้องแก้ไขที่ส่วนใดครับ

Re: สร้างDropDownlist&ComboBox

Posted: Tue Jul 30, 2013 5:25 pm
by snasui
:D สำหรับ VBA จำเป็นจะต้องเขียนมาเอง ติดตรงไหนแล้วค่อยถามกันครับ ช่วยแจ้งว่า Code ใดที่เขียนให้วางข้อมูลใน Sheet2 และ Code นั้นผิดพลาดหรือแสดงผลไม่ถูกต้องอย่างไรมาด้วยครับ

Re: สร้างDropDownlist&ComboBox

Posted: Wed Jul 31, 2013 12:25 pm
by pongpang
ขอบคุณมากครับ ทำได้แล้วครับ โดยไม่ต้องใช้ Code เพียงแต่กำหนด Properties เท่านั้น