What's in the box.
Lindu Vue is a feature-rich Dance Academy & Performing Arts HTML5 web application built as a fully functional Vue 3 app using the Composition API, Vite, and Bootstrap 4. It ships with 15+ view components, a filterable photo gallery, a blog module, map integration, written entirely with script setup and the Composition API — zero Options API usage.
Built for Vue developers delivering dance academy & performing arts html5 sites and applications. The codebase uses Vue 3 Composition API throughout — ref(), reactive(), computed(), watch(), and composables for shared logic. Single File Components (.vue) keep template, script setup, and scoped styles co-located. Replace the static JSON data sources with any REST API or headless CMS and the reactive layer adapts immediately.
Everything in the Package
- 15+ view-level Single File Components with Vue Router 4 history mode routing
- Vue 3 with script setup syntax and Vite — fast HMR dev server and optimised production build
- Vue Router 4 — history mode with lazy-loaded routes via defineAsyncComponent
- Pinia store for global state management — state, getters, and actions with localStorage persist plugin
- Bootstrap 4 — responsive grid and utility classes
- VeeValidate 4 — schema-based form validation with v-model two-way binding on all forms
- Swiper Vue — touch-friendly carousels via SwiperSlide components
- All data sourced from typed JSON in src/data/ — swap to fetch() or axios for live API
- Scoped CSS inside each .vue file — no global style bleed between components
- Retina-ready, fully responsive from 320px to 1920px+
- Vue DevTools compatible — Pinia store fully inspectable in browser
Composition API and Component Architecture
- All views use script setup — defineProps, defineEmits, ref(), computed(), and watch()
- Composables encapsulate reusable logic — useFilter, useCart, useForm, and feature-specific hooks
- Pinia store: defineStore with typed state, computed getters, and async actions
- defineAsyncComponent applied to secondary view bundles — route-level code splitting
- v-model, v-for, v-if, v-show used throughout — idiomatic Vue 3 template syntax
- storeToRefs used for reactive destructuring of Pinia store properties in setup()
- Folder structure: src/views/, src/components/, src/composables/, src/stores/, src/data/
All 15 Views
- /home-v1 — v2 — Two distinct hero and dance academy showcase layouts
- /about-us — Academy story and dance philosophy
- /services — All dance class programmes overview
- /service-detail — Individual class programme page
- /portfolio — Performance and event portfolio archive
- /portfolio-detail — Individual performance case study
- /gallery — Studio and performance photography
- /team — Instructor and dance teacher profiles
- /team-detail — Individual instructor profile and specialisation
- /faq — Common class and enrolment questions
- /blog — Dance tips and arts community news
- /blog-detail — Full article view
- /contact-us — Enrolment enquiry form and map
Key Features
- 15 Fully Designed HTML5 Pages across home, services, portfolio, team, gallery, blog, FAQ, and contact
- 2 Unique Home Layouts — distinct hero styles and dance academy showcase arrangements
- Bootstrap 4 — responsive, mobile-first grid system
- Services Module — dance class programmes with individual service detail pages
- Team Module — instructor profiles with individual team member detail pages
- Portfolio Module — performance and event portfolio with individual detail pages
- Gallery — studio and performance photography showcase
- FAQ Page — common class and enrolment questions
- Instagram Integration — social feed for community engagement and student content
- CounterUp Animated Statistics — students enrolled, classes offered, and years of experience
- Isotope Grid Filtering — filter portfolio or gallery by dance style or event type
- Owl Carousel — student testimonial and class highlight sliders
Performance and SEO
- useHead (VueUse) sets per-route title and meta description reactively for SEO
- defineAsyncComponent and Suspense code-split secondary view bundles on route change
- Vite production build applies Rollup tree-shaking, chunk splitting, and asset fingerprinting
- All images carry descriptive :alt bindings meeting WCAG 1.1.1
- Google Fonts loaded with font-display: swap to prevent invisible-text flash
Use Cases
- Dance Academy & Performing Arts HTML5 Businesses: Fast Vue 3 SPA with Composition API — reactive, composable, and easy to maintain
- Vue Developers: Composables, Pinia stores, and Vue Router 4 patterns — production architecture from day one
- Freelancers and Agencies: Deliver a polished dance academy & performing arts html5 site to clients with Vite build tooling and DevTools support
- Startups: Lightweight bundle, defineAsyncComponent code-splitting, and VeeValidate forms ready to go
Credits and Dependencies
- Vue 3 — MIT License
- Vite — MIT License
- Vue Router 4 — MIT License
- Pinia — MIT License
- VeeValidate 4 — MIT License
- Bootstrap 4 — MIT License
- Swiper Vue — MIT License
- Isotope — MIT License
- CounterUp — MIT License
- Magnific — MIT License
- Lightbox — MIT License
- Font Awesome 6 — Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT
- Google Fonts — SIL Open Font License
- Demo images: Unsplash — Unsplash License (free for commercial use, no attribution required)
- Demo images: Freepik — Freepik License (free for commercial use with attribution)
- All demo images are for preview purposes only and are NOT included in the download.
v1.0 Initial Vue Release - Vue 3 Composition API with script setup syntax throughout - Vite build tooling with fast HMR and optimised production output - 15+ view-level Single File Components with Vue Router 4 history mode - Pinia store with localStorage persist plugin for global state management - VeeValidate 4 schema-based form validation on all form views - defineAsyncComponent route-level code splitting on secondary views - useHead per-route SEO meta tags via VueUse
Open the source. Read the actual code.
Every Lindu — Dance Classes Vue.js Template template ships hand-written, semantic, and accessibility-ready. Tabs preserved. Comments in plain English. BEM naming. WCAG 2.2 AA tested. No spaghetti, no inline JavaScript scattered through the document. Your team extends without rewriting — and your users get a site that works for screen readers, keyboard navigation, and reduced-motion preferences out of the box.
<section> / <article> / <nav> tags — not div soup.prefers-reduced-motion media query disables non-essential transitions.What's changed.
- Initial release.
- Vue 3 with Composition API; reactive state and reusable components.
- Detailed documentation included with quick-start guide.
What customers actually said.
No reviews yet — be the first.
Don’t have hosting? We launch Lindu — Dance Classes Vue.js Template for you.
Skip cPanel. Skip the FTP upload. Skip the DNS configuration. Each hosting tier includes the install, plugin config, and your domain pointed live in 24 hours. Same NYC team that built the template handles your launch.
- 1 Website
- 10 GB Storage
- Free SSL
- 1 Database
- 1 Website
- 25 GB Storage
- Free SSL
- 10 Databases
- 10 Websites
- 50 GB Storage
- Free SSL (all sites)
- 25 Databases
- 25 Websites
- 75 GB Storage
- Free SSL (all sites)
- 50 Databases
- 100 GB Storage
- 4 GB RAM
- 2 CPUs
- Free SSL
- 200 GB Storage
- 8 GB RAM
- 4 CPUs
- Free SSL
- 300 GB Storage
- 16 GB RAM
- 8 CPUs
- Free SSL
- 400 GB Storage
- 32 GB RAM
- 16 CPUs
- Free SSL
Free SSL · 99.9% uptime · 24/7 support · No domain included
Every tier includes — NYC infrastructure
Save $5 on Lindu — Dance Classes Vue.js Template today.
Plus weekly drops · AICE rebuild reports · early access to designs we haven't listed publicly. Same email goes to designers shipping with Letam, Bunlicious, and Aiga.
No spam · unsubscribe anytime · 3,500+ designers ship from this list







