我正在尝试将其制作成一个随机可见且可点击的小链接按钮。我怎样才能做到这一点?

I'm trying to make this a randomly visible and clickable small link button. How can I make this work?

提问人:CryptoMynd 提问时间:11/15/2023 最后编辑:CryptoMynd 更新时间:11/15/2023 访问量:46

问:

我正在建立一个教会网站,我是编码新手,所以我不完全理解伪代码,但这是我现在所拥有的:

css:

@keyframes offsetFix {
  0% (background-color: #ffffff;)
  90% (background-color: #ffffff;)
  91% (background-color: #fefffe;)
  100% (background-color: #eeeeee;)
}
body {
  background-color: #ffffff;
  animation: offsetFix 2s linear infinite;
}
.button, a:link, a:visited {
  border: none;
  color: #960018;
  padding: 0px 0px;
  width: 3px;
  height: 3px;
  text-align: center;
  text-decoration: none;
  display: block;
  position:fixed;
  top:316px;
  /* John 3:16
  Psalms 25:7 */
  left:257px;
  z-index:7777777;
  font-size: 0px;
  border-radius: 0px;
  transition-duration: 0.01s;
  cursor: crosshair;
}
.button:hover, a:hover {
  background-color: #000000; /* Black */
  color: #000000;
  width:9px;
  height:9px;
  transform: translateY(-7px) translatex(-7px);
}
.button:active, a:active {
  background-color: #960018; /* Carmine */
  color: #ffffff;
  width:191px;
  /* Proverbs 19:1
  Psalms 27 */
  height:27px;
  font-size: 11px;
  transform: translateY(-7px) translatex(-77%);
  /* Matthew 18:22 */
}
}      
   

html(作品):

<!DOCTYPE html>
<html lang="en">

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8" >
  <meta name="viewport" content="width=device-width, initial-scale=1.0" >
  <link rel="stylesheet" href="style.css" >
  <title>Browser</title>
</head>
<body>
  <div class="button" 
    id="button" 
    style="background-color:black" 
    >Jesus was probably born on The Feast of Tabernacles / the Feast of Booths / Sukkot</div>
  <a href="https://auselessbutton.com/">Hello.</a>
  <h1>
this is a header
  </h1>
  <p>
    paragraph
  </p>
  <script src="script.js"></script>
</body>

</html>

html(不起作用):

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <link rel="stylesheet" href="style.css">
  <title>Browser</title>
  <!--place the script tag in your head section-->
<script>
  function buttonRandom(){      
  <!--this gets called by setTimeout-->
    setInterval(() => {
      if (Math.random() >= 0.5) {<!--Chance = 50%-->
        button.style.visibility = "hidden"; <!--set element's visibility to hidden-->
        } else {
          button.style.visibility = "visible"; 
        }
      }, 3e3); <!--Set the frequency of this interval to every 3 sec (3*10^3 ms)-->
    }
  };
</script>  <!--close script-->
</head>
<body onload="buttonRandom()"> <!--call to my initial function-->
  <div class="button" 
    id="button" 
    style="background-color:black" 
    >Jesus was probably born on The Feast of Tabernacles / the Feast of Booths / Sukkot</div>
  <a href="https://theuselessweb.com/">Hello.</a>
  <h1>
    header
  </h1>
  <p>
    paragraph
  </p>
  <script src="script.js"></script>
</body>

</html>

我试图设置一个间隔,以便按钮的“样式”会随机改变,这样它要么不会,要么在视觉和功能上被禁用,但按钮却完全消失了。 虽然我还没有让它成为一个有效的链接,但我希望能提供一些关于它如何完成的提示。此外,我还没有让关键帧与身体同时工作。由于页面格式的工作方式,没有脚本文件是最容易做到的,但如果绝对必要,我也许可以在其中使用脚本。

HTML CSS 按钮 浏览器 可见性

评论

0赞 j08691 11/15/2023
你的 HTML 非常无效。请通过免费验证器运行它并修复错误
0赞 CryptoMynd 11/15/2023
@j08691我现在已经这样做了。我不知道这些存在,所以谢谢。剩下的任何东西都超出了我目前的专业知识。

答:

0赞 Mordor1110 11/15/2023 #1

问题是,一旦你隐藏了按钮,你就不会恢复可见性,所以它永远保持隐藏状态。您需要添加一个 else 子句,如下所示:

  function buttonRandom() {

    let button = document.getElementById('button');
    setInterval(() => {

      if (Math.random() >= 0.5) {
        button.style.visibility = "hidden"; 
      } else {
        button.style.visibility = ""; 
      }
    }, 1e3);

  }

让我知道这是否是您正在寻找的结果:)

评论

0赞 CryptoMynd 11/15/2023
感谢您对我的括号的帮助。不幸的是,即使使用 getElementById 也不起作用。在这一点上,我愿意在脚本中完成整个事情。
0赞 Mordor1110 11/15/2023
@CryptoMynd再次检查我的答案,请务必添加“else”子句
0赞 CryptoMynd 11/15/2023
我已经更新了代码,但它仍然不起作用。
0赞 Mordor1110 11/15/2023
有一个额外的“};”,它不应该出现在脚本标记内容的末尾