使bootstrap模式可拖动并保持背景可用

时间:2017-07-12 15:49:26

标签: javascript jquery css twitter-bootstrap

我正在尝试在页面的任何位置创建一个可拖动模式,当模态打开时,我希望用户能够继续使用该页面。

我能够使用jquery-ui使模态可拖动,但是当模态打开时我仍然坚持使页面可用。用CSS尝试了几个建议,但没有一个像我希望的那样有效。

这使页面可用,但模式仅限于页面的一部分:Bootstrap Modal - make background clickable without closing out modal

与此相同:Enable background when open bootstrap modal popup

是否可以通过bootstrap模式实现这一目标?

这是我的JS:

$('#btn1').click(function() {
    var modalDiv = $('#myModal');
    modalDiv.modal({backdrop: false, show: true});

    $('.modal-dialog').draggable({
      handle: ".modal-header"
    });
});

JSFiddle链接:https://jsfiddle.net/ntLpg6hw/1/

1 个答案:

答案 0 :(得分:26)

这真的很酷!

我认为你需要的只是一点点css。

#myModal {
  position: relative;
}

.modal-dialog {
  position: fixed;
  width: 100%;
  margin: 0;
  padding: 10px;
}

你还应该添加一些jQuery来重置按钮点击时的模态位置。

$('#btn1').click(function() {
  // reset modal if it isn't visible
  if (!($('.modal.in').length)) {
    $('.modal-dialog').css({
      top: 0,
      left: 0
    });
  }
  $('#myModal').modal({
    backdrop: false,
    show: true
  });

  $('.modal-dialog').draggable({
    handle: ".modal-header"
  });
});

查看Fiddle

注意: Facebook现在正在做与外部新闻源视频类似的事情。如果您在观看视频时滚动远离视频,则会变为拖放视频。

基本上,他们的视频弹出父容器是position: relative,该容器的直接子容器是position: fixed。这里使用相同的策略。