【问题标题】:Onclick only every other clickOnclick 仅每隔一次单击
【发布时间】:2026-01-11 11:25:01
【问题描述】:

我遇到的问题是,我在 JavaScript 中创建的 onclick 函数只能在每次单击按钮时执行。添加此代码后发生这种情况(因为我想在 x 秒后隐藏类/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>

【问题讨论】:

标签: javascript html css function settimeout


【解决方案1】:

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

你再次点击它,你删除show。几乎一秒钟后,您删除hide

下一次单击会添加两者。第 4 次删除两者。以此类推。


使用 single 类并打开和关闭它。

【讨论】:

  • 我是 JavaScript 新手。你能帮我怎么做这门课吗?
  • 将单词hide 替换为show,反之亦然。 (其余的归结为您的 CSS)。
  • 该类以 hide 开头,那么为什么我要在 show 之前再次hide class onClick i> 并且不会有 hide 的。我只想让它在点击时显示 x 秒。
  • 你不会再隐藏它了。您正在切换它。因为它可以启动它,所以切换它会删除它(几乎一秒钟后再次切换它会恢复)
  • hide 是可见性:仅隐藏,show 是可见性:仅在 css 中可见。像你说的那样交换那些只会让它逆转。现在第一次点击不起作用,但第二次点击可以,依此类推。