Bootstrap实现下拉菜单

 如图:点击按钮会出现三个选项。

1、代码段

<div class="dropdown">
        <button type="button" class="btn btn-primary" data-toggle="dropdown">前端
            <span class="caret"></span>
            <!-- 出现箭头样式 -->
        </button>
        <ul class="dropdown-menu">
            <li><a href="#">
                    后端
                </a></li>
            <li><a href="#">
                    架构
                </a></li>
            <li><a href="#">
                    全栈
                </a></li>
            <!-- 使用a标签可以让列表文字之间有距离 -->
        </ul>

    </div>
    <!-- data-toggle="dropdown"是一个事件需要引入js才能执行 -->
    <script src="js/jquery-3.4.1.min.js"></script>
    <script src="js/bootstrap.min.js"></script>

 

Bootstrap下拉菜单默认只支持单选,如果需要实现多选,可以借助 JavaScript 实现。以下是一种实现方式: 首先,在 HTML 中定义一个下拉菜单,给它一个 id: ```html <div class="dropdown"> <button class="btn btn-secondary dropdown-toggle" type="button" id="multiSelectDropdown" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> 选择... </button> <div class="dropdown-menu" aria-labelledby="multiSelectDropdown"> <a class="dropdown-item" href="#" data-value="option1">选项1</a> <a class="dropdown-item" href="#" data-value="option2">选项2</a> <a class="dropdown-item" href="#" data-value="option3">选项3</a> <a class="dropdown-item" href="#" data-value="option4">选项4</a> </div> </div> ``` 注意每个选项都有一个 `data-value` 属性,用来存储选项的值。 然后在 JavaScript 中监听下拉菜单点击事件,以实现多选功能: ```javascript var selectedValues = []; // 存储已选中的值 $('.dropdown-menu a').click(function(event) { event.preventDefault(); // 阻止链接的默认行为 var value = $(this).data('value'); if (selectedValues.includes(value)) { // 如果已经选中了这个选项,则取消选中 selectedValues.splice(selectedValues.indexOf(value), 1); $(this).removeClass('active'); } else { // 否则选中这个选项 selectedValues.push(value); $(this).addClass('active'); } // 更新下拉菜单的文本 var buttonText = ''; if (selectedValues.length > 0) { buttonText = selectedValues.join(', '); } else { buttonText = '选择...'; } $('#multiSelectDropdown').text(buttonText); }); ``` 这段代码中,我们定义了一个 `selectedValues` 数组来存储已选中的值。每次点击下拉菜单中的选项时,我们先获取该选项的值,然后判断它是否已经被选中。如果已经选中,则将其从 `selectedValues` 数组中删除,并将该选项的样式移除;否则将其添加到 `selectedValues` 数组中,并添加样式表示选中状态。最后,我们更新下拉菜单按钮的文本,显示已选中的选项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值