A simple accordion component plugin for Vue 3. Follows the Accordion Design Pattern in WAI-ARIA Authoring Practices 1.1 for accessibility best practices automatically built into the plugin.
npm i vue3-accessible-accordion
or
yarn add vue3-acccessible-accordion
import { createApp } from 'vue';
import App from './App.vue'
import vue3_accessible_accordion from 'vue3-accessible-accordion';
const app = createApp(App)
.use(vue3_accessible_accordion);
.mount('#app')
import Accordion, AccordionPanel, AccordionPanelHeader, AccordionPanelContent from 'vue3-accessible-accordion';
export default {
components: {
Accordion,
AccordionPanel,
AccordionPanelHeader,
AccordionPanelContent
}
}
<accordion>
<accordion-panel>
<accordion-panel-header>Question 1</accordion-panel-header>
<accordion-panel-content>Answer to FAQ 1</accordion-panel-content>
</accordion-panel>
<accordion-panel>
<accordion-panel-header>Question 2</accordion-panel-header>
<accordion-panel-content>Answer to FAQ 2</accordion-panel-content>
</accordion-panel>
</accordion-panel>
</accordion>
<accordion>
Props
Prop | Type | Default | Required | Description |
---|---|---|---|---|
modelValue | Array | [] | No | Array of indexes of active tab panels. Defaults to an empty array - no panels will be open |
headerTag | String | h3 | No | HTML tag to be used for rendering around the button toggle of each accordion panel header |
collapsible | Boolean | true | false | Controls whether all accordion panels can be collapsed or if at least one has to be open at all times |
expandable | Boolean | false | false | Controls whether multiple accordion panels can be open at the same time |
Events
None
<accordion-panel>
Props
None
Events
None
<accordion-panel-header>
Props
None
Events
None
<accordion-panel-content>
Props
None
Events
None
yarn
yarn serve
yarn build
Author: jonbackus
Source Code: https://github.com/jonbackus/vue3-accessible-accordion
#vue #vuejs #javascript