在一个页面上打开多个模态框

时间:2016-01-13 23:38:43

标签: javascript wordpress modal-dialog modalpopups

我有一个页面,当点击页面上的相应链接时,需要打开不同的模式框。我已经将结构和javascript用于一个窗口,但我不能让它工作多个窗口。我想我需要遍历每个模态框...但是不能完全弄清楚语法。

这适用于客户的WordPress网站,我使用高级自定义字段来填充内容。该页面尚未发布,因此这是一个显示我的代码的codepen:http://codepen.io/FelixB/pen/EPvEVG

代码:

var modal = document.getElementsByClassName('modal-window');

var btn = document.getElementsByClassName("click-to-open");

var span = document.getElementsByClassName("close")[0];

for (var i = 0; i < btn.length; i++) {
  var thisBtn = btn[i]
  thisBtn.onclick = function() {
    alert("hello");

    //modal.style.display = "block";
  }
}

span.onclick = function() { 
  modal.style.display = "none";
}

window.onclick = function(event) {

}

3 个答案:

答案 0 :(得分:11)

您必须使模态唯一,以便以后能够选择它们。一种方法是通过id

<div id="modal-window-one" class="modal-window modal"></div>
<div id="modal-window-two" class="modal-window modal"></div>

您需要定义哪个窗口应该打开哪个按钮。一个可能的解决方案是通过data-attributes

<div class="click-to-open" data-modal="modal-window-one"> //will open modal one
<div class="click-to-open" data-modal="modal-window-two"> //will open modal two

然后 - 事件:

var btn = document.getElementsByClassName("click-to-open");

for (var i = 0; i < btn.length; i++) {
  var thisBtn = btn[i];
  thisBtn.addEventListener("click", function(){
    var modal = document.getElementById(this.dataset.modal);
    modal.style.display = "block";
}, false);

再次 - 这是一种可能的解决方案。

答案 1 :(得分:1)

下面是一个使用bootstrap显示多个弹出窗口的示例,还附加了一个展示示例的jsfiddle。 将类名设置为模式对话框。

<div class="modal fade myModal" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel"> <div class="modal-dialog" role="document">
<div class="modal-content">
  <div class="modal-header">
    <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
    <h4 class="modal-title" id="myModalLabel">Modal title</h4>
  </div>
  <div class="modal-body">
    ...
  </div>
  <div class="modal-footer">
    <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
    <button type="button" class="btn btn-primary">Save changes</button>
  </div>
</div>  </div></div>

实例化模态对话框。

$('.myModal').modal();

以下是正在运行的jsfiddle https://jsfiddle.net/niteshp27/msdg98vn/

答案 2 :(得分:1)

所有模态的类将保持与class="modal"相同,但是当您希望在同一屏幕上显示多个模态时,请使用"id"属性,因为Bootstrap模态是用Javascript编写的,而JS完全是JS根据ID

<div id="modal-one" class="modal fade"></div>
<div id="modal-two" class="modal fade"></div>

您需要通过使用