如何在使用JavaScript出现和消失的导航栏上添加平滑过渡效果?

huangapple go评论86阅读模式
英文:

How can I add a smooth transition effect to a navbar that appears and disappears with JavaScript?

问题

我正在尝试通过单击按钮元素时使用一些JS使导航栏出现和消失。我成功做到了这一点,但我想添加一个过渡效果,使导航栏平滑地弹出。我有点困惑,不太知道从哪里开始。

抱歉,如果我的问题表达不清楚。

这是我的HTML部分:

<section class="main-container">
   <header class="main-header"></header>
   <button class="displayer">Click Here</button>
</section>

我的CSS:

.main-container {
  width: 100vw;
  height: 100vh;
}
.main-header {
  width: 100%;
  height: 4em;
  background-color: black;

  position: absolute;
  top: 0;
}

我编写的JS部分:

const remover = document.querySelector(".displayer");

function vanish() {
  const navBar = document.querySelector(".main-header");
  const display = getComputedStyle(navBar).display;

  if (display === "none") {
    navBar.style.display = "block";
  } else {
    navBar.style.display = "none";
  }
}
remover.addEventListener("click", vanish);

如果您需要任何进一步的帮助,请告诉我。

英文:

I am trying to make a navbar appear and disappear with some JS when clicking on a button element. I managed to do that bit, but I would like to add a transition so that the navbar pops up smoothly. I am a bit confused and don't quite know where to start.

Sorry if my question is not well formulated.

This is my html bit

&lt;section class=&quot;main-container&quot;&gt;
&lt;header class=&quot;main-header&quot;&gt;&lt;/header&gt;
&lt;button class=&quot;displayer&quot;&gt;Click Here&lt;/button&gt;
&lt;/section&gt;

My CSS

.main-container {
  width: 100vw;
  height: 100vh;
}
.main-header {
  width: 100%;
  height: 4em;
  background-color: black;

  position: absolute;
  top: 0;
}

And the bit of JS I wrote

const remover = document.querySelector(&quot;.displayer&quot;);

function vanish() {
  const navBar = document.querySelector(&quot;.main-header&quot;);
  const display = getComputedStyle(navBar).display;

  if (display === &quot;none&quot;) {
    navBar.style.display = &quot;block&quot;;
  } else {
    navBar.style.display = &quot;none&quot;;
  }
}
remover.addEventListener(&quot;click&quot;, vanish);

答案1

得分: 0

你可以使用过渡并切换一个类,该类更改不透明度和变换。

const remover = document.querySelector(".displayer");
function vanish() {
  const navBar = document.querySelector(".main-header");
  navBar.classList.toggle('show');
}
remover.addEventListener("click", vanish);
.main-header {
  width: 100%;
  height: 4em;
  background-color: black;
  position: absolute;
  top: 0;
  transition: all .5s;
  transform: translateY(-100px);
  opacity: 0;
}

.main-header.show {
  transform: none;
  opacity: 1;
}

html,body{margin: 0}
<header class="main-header show"></header>
<button class="displayer" style="margin-top: 5em;">Click Here</button>
英文:

You could use a transition and toggle a class that changes opacity and transform.

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

const remover = document.querySelector(&quot;.displayer&quot;);
function vanish() {
  const navBar = document.querySelector(&quot;.main-header&quot;);
  navBar.classList.toggle(&#39;show&#39;);
}
remover.addEventListener(&quot;click&quot;, vanish);

<!-- language: lang-css -->

.main-header {
  width: 100%;
  height: 4em;
  background-color: black;

  position: absolute;
  top: 0;
  transition: all .5s;
  transform: translateY(-100px);
  opacity: 0;
}

.main-header.show {
  transform: none;
  opacity: 1;
}

html,body{margin: 0}

<!-- language: lang-html -->

&lt;header class=&quot;main-header show&quot;&gt;&lt;/header&gt; 
&lt;button class=&quot;displayer&quot; style=&quot;margin-top: 5em;&quot;&gt;Click Here&lt;/button&gt;

<!-- end snippet -->

huangapple
  • 本文由 发表于 2023年5月25日 08:02:12
  • 转载请务必保留本文链接:https://go.coder-hub.com/76328090.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定