简体   繁体   English

多个div弹出窗口

[英]Multiple div popups

I have a JavaScript to open a DIV as popup. 我有一个JavaScript可以打开DIV作为弹出窗口。 But now I want to open several different popups from different DIVS and I can't get it to work properly. 但是现在我想从不同的DIVS打开几个不同的弹出窗口,但我无法使其正常工作。

I use the following JavaScript: 我使用以下JavaScript:

<script>
window.onload = function()
{
    var show = document.getElementById('show-div');
    var hide = document.getElementById('hide-div');
    var popup = document.getElementById('popup-div');

    show.onclick = function(e)
    {
        popup.style.visibility = 'visible';
        return false;
    }

    hide.onclick = function(e)
    {
        popup.style.visibility = 'hidden';
        return false;
    }
}
</script>

and for the div I use the followin code: 对于div,我使用以下代码:

<a id="show-div" href="#">link</a>
<div id="popup-div">
<div id="popup-header">
<div id="popup-title">...Popup title...</div>
<a id="hide-div" href="#">X</a></div>
<div id="popup-body">
<p>This is the content of the div....</p>
</div>
</div>

This works for 1 link but even when I use a different DIV ID's (and associated var element like "var popup1 = document.getElementById('popup-div1');" and popup1 onclick events) I can't get it work properly. 这适用于1个链接,但是即使我使用其他DIV ID(以及关联的var元素,例如“ var popup1 = document.getElementById('popup-div1');”和popup1 onclick事件),我也无法正常工作。 How can I make it work with several links with all it's own DIV with content. 我如何使其与所有具有自己内容的DIV的几个链接一起使用。

(as I can't answer my own question, here is how I fixed it) I made it work with the following code: (因为我无法回答自己的问题,所以这是我的解决方法)我将其与以下代码一起使用:

<script>
window.onload = function()
{
    var show = document.getElementById('show-div');
    var show2 = document.getElementById('show-div2');
    var hide = document.getElementById('hide-div');
    var hide2 = document.getElementById('hide-div2');
    var popup = document.getElementById('popup-div');
    var popup2 = document.getElementById('popup-div2');

    show.onclick = function(e)
    {
        popup.style.visibility = 'visible';
        return false;
    }

    show2.onclick = function(e)
    {
        popup2.style.visibility = 'visible';
        return false;
    }

    hide.onclick = function(e)
    {
        popup.style.visibility = 'hidden';
        return false;
    }
    hide2.onclick = function(e)
    {
        popup2.style.visibility = 'hidden';
        return false;
    }
}
</script>

and

<a id="show-div" href="#">link</a>
<div id="popup-div">
<div id="popup-header">
<div id="popup-title">...Popup title...</div>
<a id="hide-div" href="#">X</a></div>
<div id="popup-body">
<p>This is the content of the div....</p>
</div>
</div>
<a id="show-div2" href="#">link2</a>
<div id="popup-div2">
<div id="popup-header">
<div id="popup-title">...Popup title2...</div>
<a id="hide-div2" href="#">X</a></div>
<div id="popup-body">
<p>This is the content of the div2....</p>
</div>
</div>

I believe following is that you want.... 我相信以下是您想要的...

Demo 演示

JS Code: JS代码:

var show = document.getElementById('show-div');
var hides = document.getElementsByClassName('hide-div');
var popups = document.getElementsByClassName("popup-div");

show.onclick = function (e) {
    for (var i = 0; i < popups.length; i++) {
        popups[i].style.visibility = 'visible';
    }
    return false;
}

for (var j = 0; j < hides.length; j++) {
    hides[j].onclick = function (e) {
        this.parentNode.parentNode.style.visibility = 'hidden';
        return false;
    }
}

HTML Code: HTML代码:

<a id="show-div" href="#">Show/Hide</a>

<div id="popup-div" class="popup-div">
    <div id="popup-header">
        <div id="popup-title">...Popup title...</div>
<a id="hide-div" class="hide-div" href="#">X</a>

    </div>
    <div id="popup-body">
        <p>This is the content of the div....</p>
    </div>
</div>
<div id="popup-div" class="popup-div">
    <div id="popup-header">
        <div id="popup-title">...Popup title...</div>
<a id="hide-div" class="hide-div" href="#">X</a>

    </div>
    <div id="popup-body">
        <p>This is the content of the div....</p>
    </div>
</div>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM