Papp Vue
This starter template built for Pointhub project to create frontend apps more easily, along with some good practices that I have learned. It's strongly opinionated, but feel free to tweak it to your needs.
Recommended IDE Setup
VSCode + Volar (and disable Vetur) + TypeScript Vue Plugin (Volar).
.vue
Imports in TS
Type Support for 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) 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 that is more performant. You can enable it by the following steps:
- Disable the built-in TypeScript Extension
- Run
Extensions: Show Built-in Extensions
from VSCode's command palette - Find
TypeScript and JavaScript Language Features
, right click and selectDisable (Workspace)
- Run
- Reload the VSCode window by running
Developer: Reload Window
from the command palette.
Customize configuration
See Vite Configuration Reference.
Dev Tools
- Vite Next Generation Frontend Tooling
- TypeScript is a strongly typed programming language that builds on JavaScript
- Vitest Unit Test Framework.
- Cypress E2E Testing
- ESLint Code Linting
- Prettier Code Formatting
UI Frameworks
- Tailwind CSS v3 - Rapidly build modern websites without ever leaving your HTML
Prerequisites
- Node.js v16.x or higher
- pnpm creates a non-flat node_modules by default, so code has no access to arbitrary packages
npm install -g pnpm
Project Setup
pnpm install
Compile and Hot-Reload for Development
pnpm dev
Type-Check, Compile and Minify for Production
pnpm build
Vitest
Run Unit Tests withpnpm test:unit
Cypress
Run End-to-End Tests withpnpm build
pnpm test:e2e # or `pnpm test:e2e:ci` for headless testing
ESLint
Lint withpnpm lint
Deploy on Netlify
Go to Netlify and select your repository, OK
along the way, and your App will be live in a minute.