ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 437|回复: 9

[已解决] checkbox类模块陷入死循环

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-11-13 11:21 | 显示全部楼层 |阅读模式
本帖最后由 tonywalker 于 2023-11-15 11:21 编辑

大佬见好,小弟这有个死循环的事,有四个checkbox1到4,写入类模块click事件;需求实现,点击其中一个checkbox后,其余编号checkbox的value值均为false,恶心的是,在设置其他编号checkbox的value为false时,又会执行click事件,这就陷入循环了;目前我已经使用checkbox类模块的mouse up事件去规避click事件循环,确实在分步运行的时候可行,但在实际运行时,checkbox它。。。。它不显示啊,就是那个勾没有了,无语死了。。。
请问,checkbox的类模块如何写啊,拜谢拜谢!!!

TA的精华主题

TA的得分主题

发表于 2023-11-13 11:29 | 显示全部楼层
你用错控件了。
既然4个控件的关系是互斥的,那就应当使用“单选按钮”,而不是“复选框”。

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-11-13 11:36 | 显示全部楼层
ggmmlol 发表于 2023-11-13 11:29
你用错控件了。
既然4个控件的关系是互斥的,那就应当使用“单选按钮”,而不是“复选框”。

大佬啊,这个是这样的,上述应用场景需要用到单选、多选的,所以选项按钮并不适用;目前,4个clikc事件分开来写click事件,即不使用类模块能实现的,但写成类模块之后,就不会了。。。

TA的精华主题

TA的得分主题

发表于 2023-11-13 11:58 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
类模块批量创建Ck的,都想着的也用类写一个click事件,我现在用类写的好有一个小bug,就是点击下一个ck时,上一个ck没有被取消,但是程序不进入死循环,想要的效果也是正确的,那个小bug有时间在优化一下,希望有大神写一个没有bug的给参考一下

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-11-13 13:23 | 显示全部楼层
寻找阳光的向日 发表于 2023-11-13 11:58
类模块批量创建Ck的,都想着的也用类写一个click事件,我现在用类写的好有一个小bug,就是点击下一个ck时, ...

哥们,我说的死循环不是代码真的进入死循环,而是逻辑进入死循环了,你现在的情况我也能做到的。。。

TA的精华主题

TA的得分主题

发表于 2023-11-13 18:00 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-11-14 10:22 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
我成功啦~该帖已完结,代码见下方,以便吧里其他需要的人

Public WithEvents mycheckbox As MSForms.CheckBox

Private Sub mycheckbox_Click()
If sh = "" Then '设置公共变量,初始为nothing
sh = Val(Right(mycheckbox.Name, 1)) '获取实际点击cb的编号
End If
With 试卷主页
    For i = 1 To 4 '遍历所有cb编号
        '若编号不等实际点击编号,且cb值为TRUE时,将其设置为false
        If i <> sh And .Controls("checkbox" & i).Value = True Then
            .Controls("checkbox" & i).Value = False
        '设置false时,会进入第二个循环,循环完毕后又会进入第一个循环,第一个循环需退出
            Exit For
        End If
    Next
    sh = "" '重新将公共变量设置为nothing
End With
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-11-14 10:30 | 显示全部楼层
山菊花 发表于 2023-11-13 18:00
参考帖子:
https://club.excelhome.net/forum.php?mod=redirect&goto=findpost&ptid=1677039&pid=1136904 ...

感谢大大大大佬回复,嗑了一天半,总算搞定了~

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-11-14 13:33 | 显示全部楼层
tonywalker 发表于 2023-11-13 13:23
哥们,我说的死循环不是代码真的进入死循环,而是逻辑进入死循环了,你现在的情况我也能做到的。。。

兄弟,快回来看看,我搞定啦,回来瞅瞅啊

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-1-25 15:13 | 显示全部楼层
第一步应该是想办法在局域网搭建个人网站;第二步将对应物料库存转换成二维码,其实就是扫码进入局域网搭建的网站,在网站上进行信息修改??
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-5-5 16:24 , Processed in 0.046125 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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