模态弹出窗口无法在页面上加载 - Javascript

时间:2018-05-01 21:20:54

标签: javascript modal-dialog popup

我在加载页面时使用了一个模态来创建一个弹出框。

我的代码在我的测试代码中运行得非常好:https://codepen.io/nico3d911/pen/yjBRrK?editors=1010

但是当我想把它放在我的真实项目中时,基本上复制粘贴,我没有任何结果:(

https://codepen.io/nico3d911/pen/odvmPR?editors=1011

HTML:

<div class="modal">
  <div class="modal-content">

    <h1>Choose your team!</h1>
    <span class="close-button" style='color:#4286f4' onclick = 'test()'>X</span>
    <span class="close-button" style='color:#e29126' onclick = 'test()'>O</span>
  </div>
</div>

CSS:

.modal {
        position: fixed;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background-color: rgba(0, 0, 0, 0.5);
        opacity: 0;
        visibility: hidden;
        transform: scale(1.1);
        transition: visibility 0s linear 0.25s, opacity 0.25s 0s, transform 0.25s;
    }
    .modal-content {
      text-align: center;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        background-color: white;
        padding: 1rem 1.5rem;
        width: 24rem;
        border-radius: 0.5rem;
    }
    .close-button {
        display: inline-block;
        margin: 0 auto;
        width: 1.5rem;
        line-height: 1.5rem;
        cursor: pointer;
        border-radius: 100%;
        border: 2px solid lightgray;
        padding: 20px;
        margin: 10px 15px 10px 15px;
        font-size:2em;
    }
    .close-button:hover {
        border: 2px solid #3fcc64;
    }
    .show-modal {
        opacity: 1;
        visibility: visible;
        transform: scale(1.0);
        transition: visibility 0s linear 0s, opacity 0.25s 0s, transform 0.25s;
    }

使用Javascript:

// Modal
window.onload = function(){
  toggleModal();
};

var modal = document.querySelector(".modal");

function toggleModal() {
        modal.classList.toggle("show-modal");
    }


function test() {
  modal.classList.toggle("show-modal");
  player.team = 'X';
  console.log(player);
}

我在页面上也有一个叠加层,但我不认为这两个有冲突......

感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

我已经复制并粘贴了你的codepen代码,看到主项目中缺少css to modal,你的css文件中也有一些html标记。

此外,你的模态还有一个类模态,它与bootstrap冲突,它也有一个名为 modal 的类。你应该给你一个不同的名字。即使这样你也必须改变你的css,因为bootstrap给所有元素一个box-sizing: border-box所以它会弄乱你的css。