bootstrap多层modal关闭后无滚动问题

bootstrap中如果在模态框弹出模态框,即多重模态框,那么在关闭模态框后,上一级的模态框无法滚动,而且滚动事件会穿透到body层。

原理是只要有modal被打开,body会被赋予modal-open这个类,使其overflow变为hidden,无法滚动;而只要有modal被关闭,body的modal-open这个类就会被remove掉。

所以解决方法如代码,非最老的一层modal监听隐藏事件,为body重新添加modal-open类。

$(".notLastModal").on("hidden.bs.modal",function(){
  $(document.body).addClass("modal-open");
});