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

Fel*_*x B 3 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) {

}
Run Code Online (Sandbox Code Playgroud)

小智 12

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

<div id="modal-window-one" class="modal-window modal"></div>
<div id="modal-window-two" class="modal-window modal"></div>
Run Code Online (Sandbox Code Playgroud)

您需要定义哪个窗口应该打开哪个按钮.一个可能的解决方案是通过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
Run Code Online (Sandbox Code Playgroud)

然后 - 事件:

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);
Run Code Online (Sandbox Code Playgroud)

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

  • 成功!在我数小时地摆弄可能性之后,这现在正在奏效。谢谢!!(显然,我无法投票 - 太新了。我会尽快为这个答案投票。)再次感谢! (2认同)