https://github.com/lorefnon/vue3-spa-starter
https://github.com/lorefnon/vue3-spa-starter
Last synced: 9 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/lorefnon/vue3-spa-starter
- Owner: lorefnon
- Created: 2024-02-19T17:31:25.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-02-19T17:31:41.000Z (over 2 years ago)
- Last Synced: 2025-09-13T11:36:32.782Z (10 months ago)
- Language: TypeScript
- Size: 26.4 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Opinionated Vue 3 SPA starter
Personal base/starter project for client-side SPAs powered by Vue3.
- Vue 3 [setup script](https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup)
- Filesystem routing with vue-router and unplugin-vue-router
- Tabler icons
- Naive UI
- Pinia for state management
- Pug syntax templates
- Sass for styling
## Recommended IDE Setup
- [VS Code](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (and disable Vetur) + [TypeScript Vue Plugin (Volar)](https://marketplace.visualstudio.com/items?itemName=Vue.vscode-typescript-vue-plugin).
## Type Support For `.vue` Imports in TS
TypeScript cannot handle type information for `.vue` imports by default, so we replace the `tsc` CLI with `vue-tsc` for type checking. In editors, we need [TypeScript Vue Plugin (Volar)](https://marketplace.visualstudio.com/items?itemName=Vue.vscode-typescript-vue-plugin) to make the TypeScript language service aware of `.vue` types.
If the standalone TypeScript plugin doesn't feel fast enough to you, Volar has also implemented a [Take Over Mode](https://github.com/johnsoncodehk/volar/discussions/471#discussioncomment-1361669) that is more performant. You can enable it by the following steps:
1. Disable the built-in TypeScript Extension
1. Run `Extensions: Show Built-in Extensions` from VSCode's command palette
2. Find `TypeScript and JavaScript Language Features`, right click and select `Disable (Workspace)`
2. Reload the VSCode window by running `Developer: Reload Window` from the command palette.