仅在每次点击时点击

时间:2017-12-22 21:02:24

标签: javascript html css function settimeout

我遇到的问题是,我在JavaScript中创建的onclick函数只能在按钮上执行。这是在添加此代码后发生的(因为我想在x秒后隐藏class / div):

popup.classList.toggle("show");
setTimeout(
function() {
popup.classList.toggle("hide");
}, 750);
}

所以换句话说,它是第一次点击然后当类显示x秒并且我将再次点击它时。没有任何事情发生,但在下一次点击它是有效的。这种情况一直持续下去。有什么问题?

我尝试复制代码,但它似乎不像在项目中那样在jsfiddle中工作。如果有人能告诉我这个代码中的问题以及如何在每次点击按钮时显示弹出窗口。

https://jsfiddle.net/xxuvwc1b/

function showpop() {
  var popup = document.getElementById("myPopup");
  popup.classList.toggle("show");
  setTimeout(
    function() {
      popup.classList.toggle("hide");
    }, 750);
}
.popup {
  background-color: black;
  position: relative;
  display: inline-block;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  font-weight: bold;
  font-family: 'Raleway', sans-serif;
  font-size: 1em;
  text-decoration: none;
  color: green;
  float: left;
  border-radius: 5px;
  border: none;
  width: 100%;
}

:focus {
  outline: 0 !important;
}

.popup .popuptext {
  visibility: hidden;
  width: 160px;
  background-color: #555;
  color: #fff;
  text-align: center;
  border-radius: 6px;
  padding: 8px 0;
  position: absolute;
  z-index: 1;
  bottom: 125%;
  left: 50%;
  margin-left: -80px;
}


/* Popup arrow */

.popup .popuptext::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -5px;
  border-width: 5px;
  border-style: solid;
  border-color: #555 transparent transparent transparent;
}

.popup .show {
  visibility: visible;
  -webkit-animation: fadeIn 1s;
  animation: fadeIn 1s;
}

.popup .hide {
  visibility: hidden;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
<button class="popup" onclick="showpop();"><span class="popuptext" id="myPopup">HERE I AM!</span>SHOW ME A POPUP</button>

1 个答案:

答案 0 :(得分:3)

您点击它并添加课程show。差不多一秒钟后,您添加了课程hide(它仍然有类show)。

您再次点击它并删除show。差不多一秒钟后,您删除班级hide

下一次点击同时添加两者。第四个删除了两个。等等。

使用单个类并打开和关闭它。