Simple accordion menu component for Vuejs
The API has changed. Check v0.0.3 documentation if you use the old version.
Install the package:
npm install vue-accordion
Then import it in your project
import Vue from 'vue'
import {vueAccordion} from 'vue-accordion'
Vue.component('vue-accordion', vueAccordion)
Just include vue
& vue-accordion
<script scr="path/to/vue.js"></script>
<script src="path/to/dist/vue-accordion.js"></script>
If you just want to play around, unpkg has ready-to-use packages from NPM.
<script src="https://unpkg.com/vue"></script>
<script src="https://unpkg.com/vue-accordion"></script>
Then register the component:
<script>
Vue.component('vue-accordion', vueAccordion)
var vm = new Vue({
...
});
</script>
Simply use it like so:
<vue-accordion :items="items" :accordionClass="acClass" :styles="styles"></vue-accordion>
Once the accordion has been rendered, it'll create the following structure:
<div class="vue-accordion">
<ul>
<!-- First menu item-->
<li>
<a>
<h2>...</h2>
<p>...</p>
</a>
</li>
<!-- Second menu item-->
<li>
<a>
<h2>...</h2>
<p>...</p>
</a>
</li>
...
</ul>
</div>
All CSS is based uppon this structure.
.vue-accordion {
...
}
.vue-accordion ul {
...
}
...
.vue-accordion ul li a h2 {
...
}
If you want to modify the styling, take a look at the accordionClass
and styles
props.
Mandatory. An array of objects to create the panels inside the accordion. Each object must have this structure:
{
title: 'First',
text: 'text',
url: '#',
image: '/images/one.jpg'
}
Take into consideration the width of the accordion and the images you use. If the image is shorter, you'll see a an awful grey background.
Optional. A string bounded to the class attribute of the main div. Defaults to vue-accordion
.
Optional. An object whose keys are other objects containing specific CSS properties to be bound to the elements created inside the accordion:
{
// this will be bound to the style attribute of all `div`s inside the accordion
div: {
height: '350px'
},
// this will be bound to the style attribute of all `ul`s inside the accordion
ul: {
color: '#F00'
},
// this will be bound to the style attribute of all `li`s inside the accordion
li: {
fontSize: '15px'
},
// this will be bound to the style attribute of all `a`s inside the accordion
a: {
padding: '30px'
},
// this will be bound to the style attribute of all `h2`s inside the accordion
h2: {
marginTop: '100px'
},
// this will be bound to the style attribute of all `p`s inside the accordion
p: {
textTransform: 'uppercase'
}
}
- Tests
- Router-link
Most of the CSS belongs to this guy