Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mayashavin/learning-vue-app

Code samples for Learning Vue book
https://github.com/mayashavin/learning-vue-app

learning-vue learning-vue3 learning-vuejs tutorial-code vue vue-3 vuejs vuex

Last synced: about 2 months ago
JSON representation

Code samples for Learning Vue book

Awesome Lists containing this project

README

        

# Learning Vue - Code samples

This is the code examples repo for my [Learning Vue](https://www.amazon.com/_/dp/1492098825?smid=ATVPDKIKX0DER&_encoding=UTF8&tag=oreilly20-20) book, aiming to help you started developing with Vue 3.

My book is available for ordering/reading on:

- [O'Reilly](https://learning.oreilly.com/library/view/learning-vue/9781492098812/)
- [Amazon](https://www.amazon.com/_/dp/1492098825?smid=ATVPDKIKX0DER&_encoding=UTF8&tag=oreilly20-20)
- [Barnes & Noble](https://www.barnesandnoble.com/w/book/1144392687)

## Recommended IDE Setup

[VSCode](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.volar) (and disable Vetur) + [TypeScript Vue Plugin (Volar)](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.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=johnsoncodehk.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.

## Customize configuration

See [Vite Configuration Reference](https://vitejs.dev/config/).

## Project Setup

Navigate to each chapter's codebase before running the following commands.

```sh
npm install
```

### Compile and Hot-Reload for Development

```sh
npm run dev
```

### Type-Check, Compile and Minify for Production

```sh
npm run build
```

### Run Unit Tests with [Vitest](https://vitest.dev/)

```sh
npm run test:unit
```

### Lint with [ESLint](https://eslint.org/)

```sh
npm run lint
```