为了账号安全,请及时绑定邮箱和手机立即绑定

如何垂直对齐展开手风琴的 CSS 箭头?

如何垂直对齐展开手风琴的 CSS 箭头?

陪伴而非守候 2023-12-04 17:17:10
我使用 CSS 而不是 Fontawesome 来生成箭头。我认为这比加载单独的图标库更有意义。然而,我很难将这些 CSS 箭头定位到中心,当它向上指向时,它看起来很棒,我认为它位于中心或至少靠近中心,但是当它向下指向时,看起来箭头向底部移动。如果有任何建议,我将不胜感激"use strict";const panelHeader = document.querySelectorAll(".panel-header");panelHeader.forEach(item => {  item.addEventListener("click", event => {    event.preventDefault();    item.parentElement.classList.toggle("open");    const panel = item.nextElementSibling;    panel.style.height = panel.style.height ? null : panel.scrollHeight + "px";  });});:root {  box-sizing: border-box;}*,*::before,*::after {  box-sizing: inherit;}body {  margin: 0;  padding: 0;}.accordion {  max-width: 1200px;  margin: 0 auto;}.accordion-container {  padding: 15px;}h2 {  color: #444;  font-size: 1.75rem;  position: relative;  padding: 0 0 25px 0;  margin: 15px 0 20px 0;}h2::after {  content: "";  position: absolute;  bottom: 0;  left: 0;  width: 50px;  height: 5px;  background: #f79c31;}.panel-container > .panel + .panel {  margin-top: 15px;}.panel {  background: #f9f9f9;  border: 1px solid #ddd;  border-radius: 0.1875em;}.panel-header {  background: #564990;  border-color: #564990;  border-top-left-radius: 0.1875em;  border-top-right-radius: 0.1875em;  position: relative;  transition: background .25s linear;}.panel-header > h4 {  margin: 0;}.panel-header > h4 > a {  position: relative;  display: block;  color: #fff;  font-size: 1.125rem;  text-decoration: none;  padding: 15px 50px 15px 15px;}.panel-header:hover {  background: #443776;}.panel-body {  height: 0;  overflow: hidden;  transition: 0.3s height 0.2s;}.panel-body-container {  padding: 15px;}.arrow {  position: absolute;  top: 22px;  right: 10px;  font-size: 1.7rem;  border: solid #fff;  border-width: 0 4px 4px 0;  display: inline-block;  padding: 5px;  opacity: .5;  transform: rotate(-135deg);  transition: transform 0.15s linear;}.arrow-up {}.panel.open .arrow {  transform: rotate(-315deg);  transform-origin: center center;}
查看完整描述

5 回答

?
慕运维8079593

TA贡献1876条经验 获得超5个赞

根据您当前的设置,最好的解决方案是 -


更改top动画类中的值。您还需要将animate值更改为 ,all以便它也以动画方式显示顶部值的变化而不跳跃。

.arrow {

  ...

  transition: all 0.15s linear;

}


.panel.open .arrow {

  transform: rotate(-315deg);

  transform-origin: center center;

  top: 18px;

}

您也可以将 更改transform-origin为100% center,但这会导致动画以奇怪的方式旋转。

如果您不想加载字体库或 SVG 图标,您还可以考虑使用内置的 HTML 箭头并旋转它们。它的行为可能更符合您的预期 - https://www.toptal.com/designers/htmlarrows/


查看完整回答
反对 回复 2023-12-04
?
aluckdog

TA贡献1847条经验 获得超7个赞

首先,您可以避免使用position: absolute解决此类问题的display: flex技巧:


const panelHeader = document.querySelectorAll(".panel-header");


panelHeader.forEach(item => {

  item.addEventListener("click", event => {

    event.preventDefault();

    item.parentElement.classList.toggle("open");

    const panel = item.nextElementSibling;

    panel.style.height = panel.style.height ? null : panel.scrollHeight + "px";

  });

});

:root {

  box-sizing: border-box;

}


*,

*::before,

*::after {

  box-sizing: inherit;

}


body {

  margin: 0;

  padding: 0;

}


.accordion {

  max-width: 1200px;

  margin: 0 auto;

}


.accordion-container {

  padding: 15px;

}


h2 {

  color: #444;

  font-size: 1.75rem;

  position: relative;

  padding: 0 0 25px 0;

  margin: 15px 0 20px 0;

}


h2::after {

  content: "";

  position: absolute;

  bottom: 0;

  left: 0;

  width: 50px;

  height: 5px;

  background: #f79c31;

}


.panel-container>.panel+.panel {

  margin-top: 15px;

}


.panel {

  background: #f9f9f9;

  border: 1px solid #ddd;

  border-radius: 0.1875em;

}


.panel-header {

  display: flex;  /* <- Use flexbox */

  justify-content: space-between;

  align-items: center;

  background: #564990;

  border-color: #564990;

  border-top-left-radius: 0.1875em;

  border-top-right-radius: 0.1875em;

  position: relative;

  transition: background .25s linear;

}


.panel-header>h4 {

  margin: 0;

}


.panel-header>h4>a {

  position: relative;

  display: block;

  color: #fff;

  font-size: 1.125rem;

  text-decoration: none;

  padding: 15px 50px 15px 15px;

}


.panel-header:hover {

  background: #443776;

}


.panel-body {

  height: 0;

  overflow: hidden;

  transition: 0.3s height 0.2s;

}


.panel-body-container {

  padding: 15px;

}


.arrow {

  /* Don't need position absolute anymore */

  margin: 10px;

  font-size: 1.7rem;

  border: solid #fff;

  border-width: 0 4px 4px 0;

  display: inline-block;

  padding: 5px;

  opacity: .5;

  transform: rotate(-135deg);

  transition: transform 0.15s linear;

}


.arrow-up {}


.panel.open .arrow {

  margin-top: -5px;  /* <- Remove arrow heigth (5px) to stay at the same level */

  transform: rotate(-315deg);

  transform-origin: center center;

}

<!DOCTYPE html>

<html>


<head>

  <meta charset="UTF-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0">

  <link rel="stylesheet" href="accordion-faq.css">

  <title>Accordion FAQ</title>

</head>


<body>

  <section class="accordion">

    <div class="accordion-container">

      <header>

        <h2>FAQs</h2>

      </header>


      <div class="panel-container">

        <div class="panel">

          <div class="panel-header">

            <h4>

              <a href="#">First question?</a>

            </h4>

            <div class="arrow">

              <div class="arrow-up"></div>

            </div>

          </div>

          <div class="panel-body">

            <div class="panel-body-container">

              <p>

                Lorem ipsum dolor sit amet, consectetur adipisicing elit. Accusantium animi blanditiis corporis dicta, dolor dolores enim facilis fuga itaque iure iusto molestiae mollitia natus nisi pariatur praesentium quo rerum vel.

              </p>

            </div>

          </div>

        </div>

        <!-- .panel -->


        <div class="panel">

          <div class="panel-header">

            <h4>

              <a href="#">Second question?</a>

            </h4>

            <div class="arrow arrow-up"></div>

          </div>

          <div class="panel-body">

            <div class="panel-body-container">

              <p>

                Lorem ipsum dolor sit amet, consectetur adipisicing elit. Accusantium animi blanditiis corporis dicta, dolor dolores enim facilis fuga itaque iure iusto molestiae mollitia natus nisi pariatur praesentium quo rerum vel.

              </p>

            </div>

          </div>

        </div>

        <!-- .panel -->

      </div>

      <!-- .panel-container -->

    </div>

    <!-- .accordion-container -->

  </section>


  <script src="accordion-faq.js"></script>

</body>


</html>


查看完整回答
反对 回复 2023-12-04
?
慕莱坞森

TA贡献1810条经验 获得超4个赞

尝试更改类top的属性,以便它不会被硬编码。.arrowtop: 50%

然后,添加到您的transform财产中translate(0, -50%)


查看完整回答
反对 回复 2023-12-04
?
噜噜哒

TA贡献1784条经验 获得超7个赞

使用topCSS 中的专有技术。

这将设置旋转箭头时箭头的顶部位置。


这是你的代码:


"use strict";


const panelHeader = document.querySelectorAll(".panel-header");


panelHeader.forEach(item => {

  item.addEventListener("click", event => {

    event.preventDefault();

    item.parentElement.classList.toggle("open");

    const panel = item.nextElementSibling;

    panel.style.height = panel.style.height ? null : panel.scrollHeight + "px";

  });

});

:root {

  box-sizing: border-box;

}


*,

*::before,

*::after {

  box-sizing: inherit;

}


body {

  margin: 0;

  padding: 0;

}


.accordion {

  max-width: 1200px;

  margin: 0 auto;

}


.accordion-container {

  padding: 15px;

}


h2 {

  color: #444;

  font-size: 1.75rem;

  position: relative;

  padding: 0 0 25px 0;

  margin: 15px 0 20px 0;

}


h2::after {

  content: "";

  position: absolute;

  bottom: 0;

  left: 0;

  width: 50px;

  height: 5px;

  background: #f79c31;

}


.panel-container > .panel + .panel {

  margin-top: 15px;

}


.panel {

  background: #f9f9f9;

  border: 1px solid #ddd;

  border-radius: 0.1875em;

}


.panel-header {

  background: #564990;

  border-color: #564990;

  border-top-left-radius: 0.1875em;

  border-top-right-radius: 0.1875em;

  position: relative;

  transition: background .25s linear;

}


.panel-header > h4 {

  margin: 0;

}


.panel-header > h4 > a {

  position: relative;

  display: block;

  color: #fff;

  font-size: 1.125rem;

  text-decoration: none;

  padding: 15px 50px 15px 15px;

}


.panel-header:hover {

  background: #443776;

}


.panel-body {

  height: 0;

  overflow: hidden;

  transition: 0.3s height 0.2s;

}


.panel-body-container {

  padding: 15px;

}


.arrow {

  position: absolute;

  top: 22px;

  right: 10px;

  font-size: 1.7rem;

  border: solid #fff;

  border-width: 0 4px 4px 0;

  display: inline-block;

  padding: 5px;

  opacity: .5;

  transform: rotate(-135deg);

  transition: transform 0.15s linear;

}


.arrow-up {


}


.panel.open .arrow {

  transform: rotate(-315deg);

  transform-origin: center center;

  top: 15px; //Do it!

}

<head>

  <meta charset="UTF-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0">

  <link rel="stylesheet" href="accordion-faq.css">

  <title>Accordion FAQ</title>

</head>

<body>

  <section class="accordion">

    <div class="accordion-container">

      <header>

        <h2>FAQs</h2>

      </header>


      <div class="panel-container">

        <div class="panel">

          <div class="panel-header">

            <h4>

              <a href="#">First question?</a>

            </h4>

            <div class="arrow"><div class="arrow-up"></div></div>

          </div>

          <div class="panel-body">

            <div class="panel-body-container">

              <p>

                Lorem ipsum dolor sit amet, consectetur adipisicing elit.

                Accusantium animi blanditiis corporis dicta, dolor dolores

                enim facilis fuga itaque iure iusto molestiae mollitia

                natus nisi pariatur praesentium quo rerum vel.

              </p>

            </div>

          </div>

        </div> <!-- .panel -->


        <div class="panel">

          <div class="panel-header">

            <h4>

              <a href="#">Second question?</a>

            </h4>

            <div class="arrow arrow-up"></div>

          </div>

          <div class="panel-body">

            <div class="panel-body-container">

              <p>

                Lorem ipsum dolor sit amet, consectetur adipisicing elit.

                Accusantium animi blanditiis corporis dicta, dolor dolores

                enim facilis fuga itaque iure iusto molestiae mollitia

                natus nisi pariatur praesentium quo rerum vel.

              </p>

            </div>

          </div>

        </div> <!-- .panel -->

      </div> <!-- .panel-container -->

    </div> <!-- .accordion-container -->

  </section>


  <script src="accordion-faq.js"></script>

</body>

现场演示:https://codepen.io/marchmello/pen/mdedGra


查看完整回答
反对 回复 2023-12-04
?
梵蒂冈之花

TA贡献1900条经验 获得超5个赞

您需要在css 上使用position: absolute和位置,如下所示:top.panel.open .arrow


"use strict";


const panelHeader = document.querySelectorAll(".panel-header");


panelHeader.forEach(item => {

  item.addEventListener("click", event => {

    event.preventDefault();

    item.parentElement.classList.toggle("open");

    const panel = item.nextElementSibling;

    panel.style.height = panel.style.height ? null : panel.scrollHeight + "px";

  });

});

:root {

  box-sizing: border-box;

}


*,

*::before,

*::after {

  box-sizing: inherit;

}


body {

  margin: 0;

  padding: 0;

}


.accordion {

  max-width: 1200px;

  margin: 0 auto;

}


.accordion-container {

  padding: 15px;

}


h2 {

  color: #444;

  font-size: 1.75rem;

  position: relative;

  padding: 0 0 25px 0;

  margin: 15px 0 20px 0;

}


h2::after {

  content: "";

  position: absolute;

  bottom: 0;

  left: 0;

  width: 50px;

  height: 5px;

  background: #f79c31;

}


.panel-container > .panel + .panel {

  margin-top: 15px;

}


.panel {

  background: #f9f9f9;

  border: 1px solid #ddd;

  border-radius: 0.1875em;

}


.panel-header {

  background: #564990;

  border-color: #564990;

  border-top-left-radius: 0.1875em;

  border-top-right-radius: 0.1875em;

  position: relative;

  transition: background .25s linear;

}


.panel-header > h4 {

  margin: 0;

}


.panel-header > h4 > a {

  position: relative;

  display: block;

  color: #fff;

  font-size: 1.125rem;

  text-decoration: none;

  padding: 15px 50px 15px 15px;

}


.panel-header:hover {

  background: #443776;

}


.panel-body {

  height: 0;

  overflow: hidden;

  transition: 0.3s height 0.2s;

}


.panel-body-container {

  padding: 15px;

}


.arrow {

  position: absolute;

  top: 22px;

  right: 10px;

  font-size: 1.7rem;

  border: solid #fff;

  border-width: 0 4px 4px 0;

  display: inline-block;

  padding: 5px;

  opacity: .5;

  transform: rotate(-135deg);

  transition: transform 0.15s linear;

}


.arrow-up {


}


.panel.open .arrow {

  transform: rotate(-315deg);

  transform-origin: center center;

  position: absolute;

  top: 30%;

}

<!DOCTYPE html>

<html>

<head>

  <meta charset="UTF-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0">

  <link rel="stylesheet" href="accordion-faq.css">

  <title>Accordion FAQ</title>

</head>

<body>

  <section class="accordion">

    <div class="accordion-container">

      <header>

        <h2>FAQs</h2>

      </header>


      <div class="panel-container">

        <div class="panel">

          <div class="panel-header">

            <h4>

              <a href="#">First question?</a>

            </h4>

            <div class="arrow"><div class="arrow-up"></div></div>

          </div>

          <div class="panel-body">

            <div class="panel-body-container">

              <p>

                Lorem ipsum dolor sit amet, consectetur adipisicing elit.

                Accusantium animi blanditiis corporis dicta, dolor dolores

                enim facilis fuga itaque iure iusto molestiae mollitia

                natus nisi pariatur praesentium quo rerum vel.

              </p>

            </div>

          </div>

        </div> <!-- .panel -->


        <div class="panel">

          <div class="panel-header">

            <h4>

              <a href="#">Second question?</a>

            </h4>

            <div class="arrow arrow-up"></div>

          </div>

          <div class="panel-body">

            <div class="panel-body-container">

              <p>

                Lorem ipsum dolor sit amet, consectetur adipisicing elit.

                Accusantium animi blanditiis corporis dicta, dolor dolores

                enim facilis fuga itaque iure iusto molestiae mollitia

                natus nisi pariatur praesentium quo rerum vel.

              </p>

            </div>

          </div>

        </div> <!-- .panel -->

      </div> <!-- .panel-container -->

    </div> <!-- .accordion-container -->

  </section>


  <script src="accordion-faq.js"></script>

</body>

</html>


查看完整回答
反对 回复 2023-12-04
  • 5 回答
  • 0 关注
  • 148 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信