今天帮同事调了一个代码,他们的项目最近在用Bootstrap做开发,突然间,他遇到了一个奇怪的问题,如果一个页面中,有多个Modal对话框的话,排列在第一个的对话框,能够正确显示,第二个,只能导致页面出现MASK层,却不能显示Dialog. 如果调整顺序,仍然是第一个能显示,第二个只有页面变暗。效果如下:
第一个,正常弹出的Dialog
第二个无法弹出,只是页面变暗的dialog
而两个dialog的代码是完全一致的,具体的代码如下:
<div class="modal fade" id="mediaMsgDialog" tabindex="-1" role="dialog"
aria-labelledby="myModalLabel" aria-hidden="true" >
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close"
data-dismiss="modal" aria-hidden="true" onclick="window.parent.closeMask()">
×
</button>
<h4 class="modal-title" id="myModalLabel">
选择多媒体信息
</h4>
</div>
<div class="modal-body" id="dlgMediaBody" style="text-align:center">
<img src="../images/89.gif">
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default"
data-dismiss="modal" onclick="window.parent.closeMask()">关闭
</button>
<button type="button" class="btn btn-primary" onclick="commitText('#menuContent')">
发布内容
</button>
</div>
</div><!-- /.modal-content -->
</div>
针对这个问题,做了一些调试,发现没有任何的JS代码错误,浏览器也没有报错。
最后,仔细想了想,估计是样式套用有冲突,以前也遇到过类似的问题,解决的办法很简单,用DIV将每个dialog的代码片段包裹一下,就能够解决这个问题了。
照着以前的解决办法处理,用DIV包一下,果然问题解决,两个dialog都能够正确弹出。
以上所述是小编给大家介绍的Bootstrap3 多个模态对话框无法显示的解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对软件开发网网站的支持!