当前位置:首页 > 办公设计 > Office教程 > 如何制作可以多项选择的下拉菜单?

如何制作可以多项选择的下拉菜单?

11个月前 (05-24)Office教程1010

今天给大家分享的表格小技巧是:如何制作显示多列同时可以选择多项的下拉菜单?
比如下图,显示三列下拉菜单,可以选择任意多个项目合并到一个单元格……

首先,咱们得有个数据表,用来填充选项菜单的数据。嗯,我们把这份工作表命名为“参数表”,数据如下图所示。A列是商品代码,B列是商品,C列是负责人。

然后,我们在需要制作选项菜单的工作表放一个列表框控件。
在【开发工具】选项卡下单击【插入】按钮,在弹出来的选项菜单中选择ActiveX控件列表框,画在当前工作表。位置随便,大小不论,丑美无关……毕竟这些你说了都不算,待会代码会重置。

需要说明的是,如果这是你在当前工作簿放置的第1个列表框控件,它会被系统默认名称为ListBox1。名字很重要,名字取不好,老婆娶不到,还记得你那个名字叫杨伟的同学吗?——下面的代码,我们都是通过名字来控制控件的一生的。
最后退出设计模式,也就是点击【开发工具】选项卡下的【设计模式】按钮。

OK,最后把以下代码复制粘贴到目标工作表的VBE编辑窗口即可。比如我们这里是粘贴到名称为“入库单”工作表。

代码如下:

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    If Target.Column <> 2 Or Target.Row < 4 Then ListBox1.Visible = False: Exit Sub
    '如果选中的单元格不是第2列,或者小于4行,也就是不在目标范围内,则退出程序
    If Target.Columns.Count > 1 Or Target.Rows.Count > 1 Then ListBox1.Visible = False: Exit Sub
    '如果选中的单元格大于1个,则退出程序
    With Sheets("参数表")
        r = .Range("a1:c" & .Cells(Rows.Count, "a").End(xlUp).Row).Value
    End With
    With ListBox1
        '调整位置到单元格处
        .Top = Target.Top 'listbox的顶端位置
        .Left = Target.Left + Target.Width 'listbox的左端位置
        .Width = 250 '宽度
        .Height = 150 '高度
        .Visible = True '可见
        '.ColumnHeads = True '显示标题行
        .ColumnCount = 3 '三列
        .ColumnWidths = "50;120;50" '设置第一列宽度50第二列宽度120……
        .List = r '数据来源
        .MultiSelect = fmMultiSelectMulti '允许通过鼠标点击的方式进行多选
        .ListStyle = fmListStyleOption '选项按钮设置为方形
    End With
End Sub

Private Sub ListBox1_Change()
    Dim i As Long, strMy As String
    With ListBox1
        If .Selected(0) = True Then .Selected(0) = False
        '如果用户选取的是标题行那么撤销选取
        For i = 1 To .ListCount - 1
        '遍历listbox的记录,如果被选中则按换行符合并
            If .Selected(i) = True Then
                strMy = strMy & vbCrLf & .List(i, 1)
                '取list的第二列
                '无论列还是行的索引都是从0开始的,因此第二列为1
            End If
        Next
    End With
    ActiveCell.Value = Mid(strMy, 3)
    '数据写入单元格
End Sub

代码有两个部分组成。

一部分是工作表的Worksheet_SelectionChange事件。当用户选择目标范围内的单元格时,显示设置列表框的位置、大小和数据。

本例中列表框只出现在B列,且行数大于3的情况下。这个可以根据实际情况,自己进行修改。
另一部分是列表框的ListBox1_Change事件,当用户选择列表框的数据时,将数据写入单元格。
其实相关代码都有注释,内急,这里就不再啰嗦了。挥挥手,下期再见。

示例文件下载,度娘她弟度盘:
https://pan.baidu.com/s/1sKf9dl64E8ocKYWxY7Edng
提取码:ebgb

原文:https://mp.weixin.qq.com/s/CJ9taJPOYJ2Tixe5rfLktA

扫描二维码推送至手机访问。

欢迎转载或分享本篇文章。

本文链接:https://www.jcba123.com/article/1571

分享给朋友:

“如何制作可以多项选择的下拉菜单?” 的相关文章

Excel表格太宽,怎么打印在一张纸上?

Excel表格太宽,怎么打印在一张纸上?

在使用Excel打印表格的时候,经常会遇到这种情况,表格太宽,一张纸打印不下,两张纸空白太多,显得很浪费。有没有什么办法能够将这样的表格缩放到一张纸上面打印出来呢?     这里给大家分享几种比较常用的方法!   01、调整宽度...

N个Excel表格文件合并成一张表,Power Query使用教程

N个Excel表格文件合并成一张表,Power Query使用教程

在工作中,我们经常会将多个Excel表格文件合并到一张表中。许多朋友可能会一张表,一张表的去复制到一起,文件少还好,文件太多,就不适合这样去做了。所以,今天特意给大家分享一种即快速,又简单的方法,使用Power Query合并表格。     Excel原始文件...

Excel也能生成制作商品条形码

Excel也能生成制作商品条形码

各位在购买一些商品的时候,一定会注意到所有商品的背后都有一个条形码。通过识别条形码,可以得到商品的厂家、名称、日期、价格等许多信息。那么条形码又是如何制作的呢?其实,Excel中就可以生成条形码,今天,小汪老师就来给大家演示一下。当然了,编码是需要向有关部门申请获得的,我这里只是教下大家将...

天天查数据,FILTER函数用过吗?

天天查数据,FILTER函数用过吗?

ILTER函数是Excel 2021版本中的新函数之一,作用是筛选符合条件的单元格。 常用写法为: =FILTER(要返回内容的数据区域,指定的条件,[没有记录时返回的内容]) 借助Excel 2021的动态溢出功能,这个函数让数据查询变得非常便捷。今天咱们就一起来分享一下这个函数的一些典型应用。...

将多列的区域或数组合并成一列,就用TOCOL函数

将多列的区域或数组合并成一列,就用TOCOL函数

今天分享TOCOL函数的几个典型应用。 这个函数目前可以在Excel 365和最新的WPS表格中使用,作用是将多列的区域或数组转换为单列。函数用法为: =TOCOL(要转换的数组或引用, [是否忽略指定类型的值], [按行/列扫描]) 其中第二参数为0或者省略该参数时,表示保留所有值。为1表示忽略空...

PPT聚光灯扫射播放效果

PPT聚光灯扫射播放效果

第一步:插入文本框,输入自己所需要文字,并填充为黑色。 第二步:点击右键,设计背景格式,背景改为黑色。此时,文字就看不到了 第三步:点击开始,形状,插入一个圆形。点击格式。 第四步:点击格式,形状填充,把圆形改为白色。 第五步:点击右键,置于底...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。