A Lightweight Accessible Accordion Using Vanilla JS

Simple Accordion is a lightweight accordion that uses vanilla JS, and define lists for markup.

bootstrap accordion accessibility, accessible accordion jquery, accessible accordion css only, accessible expandcollapse, accordion example

How to make use of it:

1. Include JavaScript accordion.js and stylesheet accordion.css on the page.

<script src="./accordion.js" defer></script>
<link href="./accordion.css" rel="stylesheet" />

2. Add a CSS class to the list of definitions.

<dl class="accordion">
  ...
</dl>

3. Add the CSS class accordion title to your accordion header links as follows:

<dl class="accordion">
  <dt>
    <a aria-expanded="fasle" href="#"  tabindex="0">
      <div class="accordion-heading">
        Accordion Header Link.
      </div>
    </a>
  </dt>
  <dd tabindex="0">
    <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
  </dd>
  <dt>
    <a aria-expanded="fasle" href="#"  tabindex="0">
      <div class="accordion-heading">
        Accordion Header Link
      </div>
    </a>
  </dt>
  <dd tabindex="0">
    <p>Accordion content goes here</p>
  </dd>
  <dt>
    <a aria-expanded="fasle" href="#"  tabindex="0">
      <div class="accordion-heading">
        Accordion Header Link
      </div>
    </a>
  </dt>
  <dd tabindex="0">
    <p>Accordion content goes here</p>
  </dd>
</dl>

4. Override the default styles of the accordion component.

.accordion > dt {
  border: 1px solid black;
  border-bottom: 0;
  padding: 10px;
  position: relative;
}

Accessible Accordion With Vanilla JavaScript, simple accordion Plugin/Github


See Demo And Download

Official Website(mwhittaker00): Click Here

This superior jQuery/javascript plugin is developed by mwhittaker00. For extra Advanced Usages, please go to the official website.

Related Posts

HStack-and-VStack-in-CSS

CSS Layout Components Horizontal/Vertical Stack | HStack and VStack

HStack and VStack in CSS – CSS layout components that (basically) stack anything horizontally and vertically. A pure CSS library that makes it easy to stack elements…

Floating-Whatsapp-Chat-Button

How to Add Floating Whatsapp Chat Button In HTML | venom-button

Venom Button is a very simple plugin for the jQuery floating WhatsApp button. Adds a floating button to your site that calls WhatsApp Click to Chat API. It will automatically start the WhatsApp…

Data-Table-Generator-Tabulator

Interactive Data Table Generator with JS/jQuery and JSON | Tabulator

Tabulator allows you to create interactive tables in seconds from any HTML Table, JavaScript array, AJAX data source, or JSON format data. Just include the library in your…

alert-confirm-prompt-attention-js

Simple Alert, Confirm, Prompt Popup Using Vanilla JavaScript Library | attention.js

JavaScript provides various built-in functionality to display popup messages for different purposes. Attention JS is a vanillaJS plugin used to create a custom alert, confirm, or Prompt…

Bootstrap-4-Sidebar-Menu-Responsive-Template

Bootstrap 4 Sidebar Menu Responsive Template | MDB

Bootstrap Side Navbar – Responsive sidebar template based on the Bootstrap 4 framework. An easy-to-use, totally responsive, Google Material Design impressed aspect navigation for modern web app…

Bootstrap-4-Toast-Notification-Plugin

Lightweight Bootstrap 4 Toast Notification Plugin | BS4 Advanced Toast

A lightweight Bootstrap 4 Toast Notification plugin integrated with JS/jQuery. bs4-toast.js is a JavaScript library that enhances the native Bootstrap toast component with icons, buttons, callbacks, and…

Leave a Reply

Your email address will not be published. Required fields are marked *