A simple, scalable, and powerful architecture for building production ready Vue applications.
This repository is a migration of bulletproof-react to Vue and its ecosystem.
Still work in progress. In particular, items labeled WIP have not yet been migrated.
Vue is a great tool for building frontend applications. It has a very diverse ecosystem with hundreds of great libraries for literally anything you might need. However, it can be overwhelming to be forced to make so many choices. It is also very flexible, you can write Vue applications in any way you like but that flexibility comes with a cost. Since there is no pre-defined architecture developers can follow, it often leads to messy, inconsistent, or over-complicated codebases.
This is an attempt to present a way of creating Vue applications using the best tools in the ecosystem with a good project structure that scales very well. It is based on the experience of working with many different codebases, and this architecture turns out to be the most effective one.
The goal of this repo is to serve as a collection of resources and good practices when developing Vue applications. It is supposed to showcase solving most of the real-world problems of an application in a practical way and help developers writing better applications.
Feel free to explore the codebase to get the most value out of the repo.
This is not supposed to be a template, boilerplate or a framework. It is an opinionated guide that shows how to do some things in a certain way. You are not forced to do everything exactly as it is shown here, decide what works best for you and your team and stay consistent with your style.
- ๐ป Application Overview
- โ๏ธ Project Configuration
- ๐๏ธ Style Guide
- ๐๏ธ Project Structure
- ๐งฑ Components And Styling
- ๐ก API Layer
- ๐๏ธ State Management
- [WIP] ๐งช Testing
โ ๏ธ Error Handling- ๐ Security
- [WIP] ๐ Performance
- ๐ Deployment
- ๐ Additional Resources
Contributions are always welcome! If you have any ideas, suggestions, fixes, feel free to contribute. You can do that by going through the following steps:
- Clone this repo
- Create a branch:
git checkout -b your-feature
- Make some changes
- Test your changes
- Push your branch and open a Pull Request