Stripe
Technology, Finance
I started Vue as a personal project when I was working at Google Creative Labs in 2013. My job there involved building a lot of UI prototypes. After hand-rolling many of them with vanilla JavaScript and using Angular 1 for a few, I wanted something that captured the declarative nature of Angularβs data binding, but with a simpler, more approachable API. Thatβs how Vue started.
In late 2015 I started to seriously consider working full-time on Vue since its growth was very promising, and I had many ideas that I thought would push the project even further. In February 2016 I started a Patreon campaign where users and companies could make monthly pledges to support my work on Vue. To my surprise, the campaign got traction quickly, and now Iβm able to work on Vue full-time. Iβm extremely grateful to the community for making this a reality.
Over time many wonderful community members have joined me and we now have a core team and other active community members helping me with all aspects of the project. Vue is currently funded by the community through Patreon.
Working on Vue was how I grew as a developer: It motivated me to research and learn whatever it took to implement the features I wanted, and I had to hold myself up to decent engineering standards to keep the project maintainable. When the project got bigger and more opinions started to surface, I started to understand the art of trade-offs in software engineering and how different goals can lead to different design decisions.
As Vue grows in popularity, comparisons with other frameworks have led to long debates. Being the maintainer of Vue actually allowed me to look at all this from a different perspective and realize how important it is to keep an open mind and embrace the fact that having choices is a good thing.
βWorking on Vue was how I grew as a developer: It motivated me to research and learn whatever it took to implement the features I wanted.β
Properly prioritizing different types of tasks. For a very long time I tried to fix issues as fast as possible and only work on planned features after. My experience so far is that this model isnβt sustainable. My work schedule became very ad-hoc because issues can arrive at unpredictable times, and itβs hard to know how long it will take to triage and fix certain bugs.
Iβm now experimenting with a different model: I have unsubscribed from most of the projectsβ notifications and only triage issues in batch with a fixed schedule. The core team members filter the incoming issues and only ping me when something is critically wrong. This allows me to take better control of my time and stay focused.
As a maintainer, most of the time you get pinged for problems in your project. Although it happens less often, itβs very heart-warming when users send you encouraging messages telling you how your project has made their work more enjoyable and how grateful they are for that. Iβm quite proud that all the private messages I got on Reddit are the extremely positive type.
βItβs very heart-warming when users send you encouraging messages telling you how your project has made their work more enjoyable and how grateful they are for that.β
Donβt press yourself too hard, take breaks from time to time, and take it easy when there is negative feedback. Keep in mind that you are already creating value for all your users and issues are just room for improvement.
The greatest contribution to Vue would be things that can benefit the entire community: experimenting with new ideas, educational resources, or sharing solutions to encountered problems as reusable plugins, components, and CLI templates.
There are already a ton of these, but as of now the discoverability of high-quality resources could use some improvement. Weβd greatly appreciate input from the community on this.
Project
Location
Day job
From flexible hosting to dataβpowered security, get everything your team needs to build at their best.
Start collaborating with your team on GitHub
Advanced collaboration and support for teams
Security, compliance, and flexible deployment for enterprises
Want to use GitHub on your own? Check out our plans for individuals