JavaScript

超轻量级php框架startmvc

Bootstrap3 多个模态对话框无法显示的解决方案

更新时间:2020-04-25 15:10:01 作者:startmvc
今天帮同事调了一个代码,他们的项目最近在用Bootstrap做开发,突然间,他遇到了一个奇怪

今天帮同事调了一个代码,他们的项目最近在用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 多个模态对话框无法显示的解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

bootstrap 模态对话框