bootstrap弹出多个模态框_bootstrap中多个modal弹出的问题解决方案

在bootstrap的官网中了解到modal弹出只是支持单个,对于嵌套的modal并没有提供相应的解决方案,本文这里就根据网上找到的案例进行整理得到。

解决方案

主要是通过对modal的zindex进行赋值,使最新弹出的modal总是在最前面的。

$(document).ready(function () {

// 通过该方法来为每次弹出的模态框设置最新的zIndex值,从而使最新的modal显示在最前面

$(document).on('show.bs.modal', '.modal', function (event) {

var zIndex = 1040 + (10 * $('.modal:visible').length);

$(this).css('z-index', zIndex);

// setTimeout(function() {

// $('.modal-backdrop').not('.modal-stack').css('z-index', zIndex - 1).addClass('modal-stack');

// }, 0);

});

});

Paste_Image.png

整个样例代码如下:

测试多个modal弹出功能

层叠的Bootstrap Modal样例

弹出第一个modal

$(document).ready(function () {

// 通过该方法来为每次弹出的模态框设置最新的zIndex值,从而使最新的modal显示在最前面

$(document).on('show.bs.modal', '.modal', function (event) {

var zIndex = 1040 + (10 * $('.modal:visible').length);

$(this).css('z-index', zIndex);

// setTimeout(function() {

// $('.modal-backdrop').not('.modal-stack').css('z-index', zIndex - 1).addClass('modal-stack');

// }, 0);

});

});

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现多个框,可以通过动创建多个框的方式来实现。以下是一种实现方法: 1. 在 HTML 添加一个按钮,用于触发框: ```html <button id="btnOpenModal" class="btn btn-primary">打开框</button> ``` 2. 在 JavaScript 编写代码,用于动创建框: ```javascript // 框计数器,用于生成唯一的 ID var modalCount = 0; // 创建框函数 function createModal() { // 创建框 HTML var modalHTML = '<div id="modal' + modalCount + '" class="modal fade" tabindex="-1" role="dialog">'; modalHTML += '<div class="modal-dialog" role="document">'; modalHTML += '<div class="modal-content">'; modalHTML += '<div class="modal-header">'; modalHTML += '<h5 class="modal-title">框标题</h5>'; modalHTML += '<button type="button" class="close" data-dismiss="modal" aria-label="Close">'; modalHTML += '<span aria-hidden="true">×</span>'; modalHTML += '</button>'; modalHTML += '</div>'; modalHTML += '<div class="modal-body">'; modalHTML += '<p>框内容</p>'; modalHTML += '</div>'; modalHTML += '<div class="modal-footer">'; modalHTML += '<button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>'; modalHTML += '<button type="button" class="btn btn-primary">保存</button>'; modalHTML += '</div>'; modalHTML += '</div>'; modalHTML += '</div>'; modalHTML += '</div>'; // 将框 HTML 添加到页面 $('body').append(modalHTML); // 增加计数器,确保每个框具有唯一的 ID modalCount++; // 返回最新创建的框的 ID return 'modal' + (modalCount - 1); } ``` 3. 在 JavaScript 编写代码,用于打开框: ```javascript // 点击按钮时打开框 $('#btnOpenModal').click(function () { // 创建一个新的框 var modalId = createModal(); // 打开新的框 $('#' + modalId).modal('show'); }); ``` 这样就可以通过点击按钮来打开多个框了。每次点击按钮时,都会动创建一个新的框,并打开它。注意,这里使用了 jQuery 和 Bootstrap 的 JavaScript 插件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值