Bootstrap modal 多弹窗之叠加引起的滚动条,遮罩阴影问题

上篇提到的’ Bootstrap modal 多弹窗之叠加关闭阴影遮罩问题’
我总结了下,对于modal多窗口叠加引起的遮罩,滚动条,无法弹出窗口的问题,查看源代码,我总结了一种方法可以一次性解决所有这些问题,而不影响原有modal功能,并且实现了多窗口叠加。

对于多窗口,如果我们将第二个,乃至第三个,第四个modal的根节点,移植到body下面,就不会出现了以上问题。
具体该如何操作,请看以下代码:

通常我们遇到多弹窗的问题,是出现在modal套modal中,也就是:

<div class='fade modal' id='modal_demo' style='display:none'>
                  <div class='modal-dialog modal-max-lg'>
                    <div class='modal-content'>
                      <div class='modal-header'>
                        <button class='close' id='feature-mapping-dialog-form_close_button' type='button'>x</button>
                        <h4 class='modal-title'>Map Features</h4>
                      </div>
                      <div class='modal-body'>
                        <div>
                           <table>
                              <tr>
                                 .....
                                 <td>
                                   <div class='fade modal' id='modal_demo' style='display:none'>
                  <div class='modal-dialog modal-max-lg'>
                    <div class='modal-content'>
                      <div class='modal-header'>
                         <button class='close' id='feature-mapping-dialog-form_close_button' type='button'>x</button>
                        <h4 class='modal-title'>Map Features</h4>
                      </div>
                      <div class='modal-body'>   
                        ...

第二个窗口是在click事件中,弹出,在第一个modal层上出现。这里,我们可以在common.js中写如下代码:

$('#click_demo').live('click', function(e) {
    $("#body").append("<div class='fade modal' id='model_dialog'/>");
    $("#body").children().last().append($(this).next().html());
    $("#body").children().last().modal();
});
$("#click_demo").live('hidden.bs.modal',function(){
    $("#body").children().last().remove();
})

click代码:

<div id="click_demo",class="idel",style="display:inline" >
  <img alt='click details' src="/icons/demo.png" title="click to details">
<div class='fade modal' id='modal_demo' style='display:none'>
                  <div class='modal-dialog modal-max-lg'>
                    <div class='modal-content'>
                      <div class='modal-header'>
                        <button class='close' id='feature-mapping-dialog-form_close_button' type='button'>x</button>

以上是我处理的逻辑方式,不妥之处,请指正,谢谢。
name: eric
email: oldlock1988@163.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值