Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 2789|回复: 12

[已解决]请【老师】帮忙解决!看看为什么会这样!

[复制链接]
发表于 2017-7-24 13:39 | 显示全部楼层 |阅读模式
GIF说明原因:
123.gif


附件在这里:

2017-07-24_132649.jpg
附件: 生成ComboBoxtest-03.rar (20.94 KB, 下载次数: 12)
 楼主| 发表于 2017-7-24 13:41 | 显示全部楼层
回复

使用道具 举报

发表于 2017-7-24 14:27 | 显示全部楼层
因为你再点击按钮时,并未把原来的10个COMBOBOX替换掉,只是覆盖上去了而已,然后再写入1~10的值时,还是写在原来的COMBOBOX内,所以看不到了,但是为什么两次添加的控件可以重复命名,这我真不明白,而且添加几次后,获取所有控件名时确实发现同样名称的控件非常多,但是无法正确取得它们的值。
回复

使用道具 举报

发表于 2017-7-24 14:32 | 显示全部楼层
第二个问题可以这样解决:
ComboBox2 = Me.Controls("ComboBox3W").Value
回复

使用道具 举报

发表于 2017-7-24 14:45 | 显示全部楼层
第一个问题解决方法,自动生成按钮时先删除原来已存在的控件:
  1. Private Sub CommandButton1_Click()
  2. On Error Resume Next
  3. Dim i&, tp&, lft&, wid&, hgt&, CB
  4. tp = 100: hgt = 20: wid = 76: CB = ComboBox1.Value
  5. For i = 1 To 10
  6.   Controls.Remove CB & i & "W"
  7. Next i
  8. For i = 1 To 10
  9.   With Controls.Add("Forms." & CB & ".1")
  10.       .Visible = True
  11.       .Name = CB & i & "W"
  12.       .Top = tp
  13.       .Left = lft
  14.       .Height = hgt
  15.       .Width = wid
  16.       .SpecialEffect = 6
  17.       lft = lft + .Width
  18.   End With
  19. Next i
  20. Call CommandButton2_Click
  21. End Sub
复制代码
回复

使用道具 举报

发表于 2017-7-24 14:46 | 显示全部楼层
这样也行,省一次循环。
  1. Private Sub CommandButton1_Click()
  2. On Error Resume Next
  3. Dim i&, tp&, lft&, wid&, hgt&, CB
  4. tp = 100: hgt = 20: wid = 76: CB = ComboBox1.Value
  5. For i = 1 To 10
  6.   Controls.Remove CB & i & "W"
  7.   With Controls.Add("Forms." & CB & ".1")
  8.       .Visible = True
  9.       .Name = CB & i & "W"
  10.       .Top = tp
  11.       .Left = lft
  12.       .Height = hgt
  13.       .Width = wid
  14.       .SpecialEffect = 6
  15.       lft = lft + .Width
  16.   End With
  17. Next i
  18. Call CommandButton2_Click
  19. End Sub
复制代码
回复

使用道具 举报

发表于 2017-7-24 15:16 | 显示全部楼层    本楼为最佳答案   
实际上call commandbutton2语句也可以不要。
Private Sub CommandButton1_Click()
On Error Resume Next
Dim i&, tp&, lft&, wid&, hgt&, CB
tp = 100: hgt = 20: wid = 76: CB = ComboBox1.Value
For i = 1 To 10
  Controls.Remove CB & i & "W"
  With Controls.Add("Forms." & CB & ".1")
      .Visible = True
      .Name = CB & i & "W"
      .Value = .Name
      .Top = tp
      .Left = lft
      .Height = hgt
      .Width = wid
      .SpecialEffect = 6
      lft = lft + .Width
  End With
Next i
End Sub
回复

使用道具 举报

发表于 2017-7-24 18:29 | 显示全部楼层
第一个循环还是要的
For Each CT In Controls   '移除控件
        If InStr(CT.Name, "Box") Then Controls.Remove (CT.Name)
        If InStr(CT.Name, "Lab") Then Controls.Remove (CT.Name)
Next
回复

使用道具 举报

 楼主| 发表于 2017-7-24 20:36 | 显示全部楼层
大灰狼1976 发表于 2017-7-24 15:16
实际上call commandbutton2语句也可以不要。
Private Sub CommandButton1_Click()
On Error Resume Next
...

O(∩_∩)O谢谢【大灰狼老师】
回复

使用道具 举报

 楼主| 发表于 2017-7-24 20:37 | 显示全部楼层
zjdh 发表于 2017-7-24 18:29
第一个循环还是要的
For Each CT In Controls   '移除控件
        If InStr(CT.Name, "Box") Then Contr ...

O(∩_∩)O谢谢
zjdh老师!!!

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-25 12:06 , Processed in 0.570132 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表