Mega Menu

Default mega menu

Use this example to show a list of links aligned on three columns inside the mega menu dropdown.

<script>
 let menu = [
    {name: 'About us', href: '/about},
    {name: 'Blog', href: '/blog},
    {name: 'Contact us', href: '/contact},
    {name: 'Library', href: '/library},
    {name: 'Newsletter', href: '/news},
    {name: 'Support Center', href: '/support},
    {name: 'Resources', href: '/resource},
    {name: 'Playground', href: '/play},
    {name: 'Terms', href: '/tersm},
    {name: 'Pro Version', href: '/pro},
    {name: 'License', href: '/license},
  ];
</script>

<Navbar let:hidden let:toggle>
  <NavBrand href="/">
    <img src="https://flowbite.com/docs/images/logo.svg" class="mr-3 h-6 sm:h-9" alt="Flowbite Logo"/>
    <span class="self-center whitespace-nowrap text-xl font-semibold dark:text-white">Flowbite</span>
  </NavBrand>
  <NavHamburger on:click={toggle} />
  <NavUl {hidden}>
    <NavLi href="/">Home</NavLi>
    <NavDropdown name="Mega menu">
      <MegaMenu items={menu} let:item>
        <a href={item.href} class="hover:text-blue-600 dark:hover:text-blue-500">{item.name}</a>
      </MegaMenu>
    </NavDropdown>
    <NavLi href="/services">Services</NavLi>
    <NavLi href="/services">Products</NavLi>
    <NavLi href="/services">Contact</NavLi>
  </NavUl>
</Navbar>

Mega menu with icons

This example of a mega menu dropdown can be used to also show an icon near the text of the link.

<script>
    let menu = [
    {name: 'About us', href: '/about', icon: UserCircle},
    {name: 'Blog', href: '/blog', icon: UserCircle},
    {name: 'Contact us', href: '/contact', icon: UserCircle},
    {name: 'Library', href: '/library', icon: UserCircle},
    {name: 'Newsletter', href: '/news', icon: UserCircle},
    {name: 'Support Center', href: '/support', icon: UserCircle},
    {name: 'Resources', href: '/resource', icon: UserCircle},
    {name: 'Playground', href: '/play', icon: UserCircle},
    {name: 'Terms', href: '/tersm', icon: UserCircle},
    {name: 'Pro Version', href: '/pro', icon: UserCircle},
    {name: 'License', href: '/license', icon: UserCircle},
  ];
</script>
...
<NavDropdown name="Mega menu">
  <MegaMenu items={menu} let:item>
    <a href={item.href} class="flex items-center hover:text-blue-600 dark:hover:text-blue-500">
      <span class="sr-only">{items.name}</span>
      <svelte:component this={item.icon} class="w-4 h-4 mr-2" />{item.name}
    </a>
  </MegaMenu>
</NavDropdown>

Full width dropdown

Use this example to show a mega menu dropdown that spans the entire width of the document page.

<script>
  let menu2 = [
    {name: 'Online Stores', help: "Connect with third-party tools that you're already using."},
    {name: 'Segmentation', help: "Connect with third-party tools that you're already using."},
    {name: 'Marketing CRM', help: "Connect with third-party tools that you're already using."},

    {name: 'Online Stores', help: "Connect with third-party tools that you're already using."},
    {name: 'Segmentation', help: "Connect with third-party tools that you're already using."},
    {name: 'Marketing CRM', help: "Connect with third-party tools that you're already using."},

    {name: 'Audience Management', help: "Connect with third-party tools that you're already using."},
    {name: 'Creative Tools', help: "Connect with third-party tools that you're already using."},
    {name: 'Marketing Automation', help: "Connect with third-party tools that you're already using."},
  ];
</script>
...
<NavDropdown name="Mega menu">
  <MegaMenu full items={menu2} let:item>
    <a href="/" class="block p-3 rounded-lg hover:bg-gray-50 dark:hover:bg-gray-700 h-full">
    <div class="font-semibold dark:text-white">{item.name}</div>
    <span class="text-sm font-light text-gray-500 dark:text-gray-400">{item.help}</span>
    </a>
  </MegaMenu>
</NavDropdown>

Full width with CTA

This example can be used to also show a CTA button or link next to the menu items inside the dropdown.

<script>
  let menu = [
    {name: 'About us', href: '/about'},
    {name: 'Blog', href: '/blog'},
    {name: 'Contact us', href: '/contact'},
    {name: 'Library', href: '/library'},
    {name: 'Newsletter', href: '/news'},
    {name: 'Support Center', href: '/support'},
    {name: 'Resources', href: '/resource'},
    {name: 'Playground', href: '/play'},
    {name: 'Terms', href: '/tersm'},
    {name: 'Pro Version', href: '/pro'},
    {name: 'License', href: '/license'},
  ];
</script>
...
<NavDropdown name="Mega menu">
  <MegaMenu full items={menu} let:item>
    <a href={item.href} class="hover:underline hover:text-blue-600 dark:hover:text-blue-500">{item.name}</a>
    <div slot="extra" class="">
        <h2 class="mt-4 mb-2 font-semibold text-gray-900 dark:text-white">Our brands</h2>
        <p class="mb-2 p-0 text-sm font-light text-gray-500 dark:text-gray-300">At Flowbite, we have a portfolio of brands that cater to a variety of preferences.</p>
        <a href="/" class="inline-flex items-center text-sm font-medium text-blue-600 hover:underline hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-700">
            Explore our brands 
            <span class="sr-only">Explore our brands </span>
            <ArrowSmRight class="w-4 h-4 ml-1"/>
        </a>
    </div>
  </MegaMenu>
</NavDropdown>

Full width with image

This example can be used to also show a CTA with a backdround image inside the dropdown next to the other menu items and links.

...
<NavDropdown name="Mega menu">
  <MegaMenu full items={menu} let:item>
    <a href={item.href} class="hover:underline hover:text-blue-600 dark:hover:text-blue-500">{item.name}</a>
    <a slot="extra" href="/" class="block mt-4 p-4 text-left bg-local bg-gray-500 bg-center bg-no-repeat bg-cover rounded-lg bg-blend-multiply hover:bg-blend-soft-light dark:hover:bg-blend-darken" style="background-image: url(/images/nature-1.jpeg)">
        <p class="mb-5 max-w-xl text-sm p-0 font-extrabold tracking-tight leading-tight text-white">Preview the new Flowbite dashboard navigation.</p>
        <Button>Get started</Button>
    </a>
  </MegaMenu>
</NavDropdown>

Props

The component has the following props, type, and default values. See types page for type information.

Name Type Default
items LinkTypeLike[] []
full boolean false

References