我在加载页面时使用了一个模态来创建一个弹出框。
我的代码在我的测试代码中运行得非常好: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);
}
我在页面上也有一个叠加层,但我不认为这两个有冲突......
感谢您的帮助!
答案 0 :(得分:1)
我已经复制并粘贴了你的codepen代码,看到主项目中缺少css to modal,你的css文件中也有一些html标记。
此外,你的模态还有一个类模态,它与bootstrap冲突,它也有一个名为 modal 的类。你应该给你一个不同的名字。即使这样你也必须改变你的css,因为bootstrap给所有元素一个box-sizing: border-box
所以它会弄乱你的css。