【问题标题】:Dropup in TailwindCSS / AlpineJSTailwindCSS / AlpineJS 中的下拉菜单
【发布时间】:2020-09-07 23:14:44
【问题描述】:

有谁知道如何在 TailwindCSS /AlpineJS 中构建“dropup”?我知道如何建立下拉菜单,但无法制作下拉菜单。

我的下拉菜单:

<link href="https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css" rel="stylesheet">
<script src="https://cdn.jsdelivr.net/gh/alpinejs/alpine@v2.x.x/dist/alpine.min.js" defer></script>
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" />
<meta charset="utf-8" />

      <div class="flex-shrink-0 flex border-t border-gray-200 p-4">
        <a href="#" class="flex-shrink-0 group block">
          <div class="flex items-center">
            <div @click.away="open = false" class="relative" x-data="{ open: false }">
                  <div>
                    <button @click="open = !open" class="max-w-xs flex items-center text-sm rounded-full text-white focus:outline-none focus:shadow-solid transition ease-in-out duration-150">
                      <img class="inline-block h-8 w-8 rounded-full" src="https://images.unsplash.com/photo-1472099645785-5658abf4ff4e?ixlib=rb-1.2.1&amp;ixid=eyJhcHBfaWQiOjEyMDd9&amp;auto=format&amp;fit=facearea&amp;facepad=2&amp;w=256&amp;h=256&amp;q=80" alt="">
            <div class="ml-3">
              <p class="text-sm leading-5 font-medium text-gray-700 group-hover:text-gray-900">
                John Doe
              </p>
              <p class="text-xs text-left leading-4 font-medium text-gray-500 group-hover:text-gray-700 transition ease-in-out duration-150">
                View profile
              </p>
            </div>                      
                    </button>
                  </div>
                  <div x-show="open" x-transition:enter="transition ease-out duration-100" x-transition:enter-start="transform opacity-0 scale-95" x-transition:enter-end="transform opacity-100 scale-100" x-transition:leave="transition ease-in duration-75" x-transition:leave-start="transform opacity-100 scale-100" x-transition:leave-end="transform opacity-0 scale-95" class="origin-top-right absolute left-0 mt-2 -mr-1 w-48 rounded-md shadow-lg">
                    <div class="py-1 rounded-md bg-white shadow-xs relative">
                      <a href="#" class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 transition ease-in-out duration-150">Your Profile</a>
                      <a href="#" class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 transition ease-in-out duration-150">Settings</a>
                      <a href="#" class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 transition ease-in-out duration-150">Sign out</a>
                    </div>
                  </div>
                </div>

          </div>
        </a>
      </div>

https://jsfiddle.net/s4m6vea7/

谢谢!

【问题讨论】:

  • 为了避免混淆,您能否定义一下“dropup”的含义,或许可以通过插图或其他方式。
  • 感谢您的反应!通常下拉菜单会下降。我想要相反的:i.ytimg.com/vi/9u7Jk9dE8do/maxresdefault.jpg

标签: javascript css tailwind-css alpine.js


【解决方案1】:

改动很小

我确实知道如何构建它。建立下拉菜单很容易。将其均匀分布更加困难。在this code pen 中,我以您的示例为例,并使其在没有太大变化的情况下工作。我将bottom-0 类添加到下拉列表中。我还添加了一个mb-12 类,它将位于按钮上方。不过,这不是一个超级动态修复,您必须在使用它的每个元素的底部添加边距。

固溶体

我将this code pen 更改为在下拉菜单周围有一个包装器。通过包装下拉菜单,我可以让 bottom-0 类从下拉菜单的顶部开始。无论下拉高度如何,添加的任何边距都将保持一致。

【讨论】:

  • 这太棒了!谢谢雅各布的帮助。真的很感激!
猜你喜欢
  • 2021-03-06
  • 2022-12-05
  • 2022-08-19
  • 2021-12-03
  • 2022-12-13
  • 2020-09-07
  • 2012-07-05
  • 1970-01-01
  • 2015-03-15
相关资源
最近更新 更多