Fathur Rahman
Posted in Productivity

Plum Development Diaries, Episode 04: Choosing the Javascript Framework

Welcome to our development diaries for Project Plum

We’re a building a work management software for remote workers and we’ll be sharing details of the development process with our community. If you want to know how it all started, just check these blogposts before you move forward:

Introduction: We’re Building a Tool For Remote Workers Plum Development Diaries, Episode 01: Why Build This Tool? Plum Development Diaries, Episode 02: Do’s and Don’ts Plum Development Diaries, Episode 03: Asynchronous communication by default

Choosing the Javascript framework

When we started developing Plum, our original aim was to quickly develop the MVP and so, we started using it to validate our idea. Since Plum features mainly live at the front end and require a lot of Javascript code, we decided to use matured JS framework to build it.

We did consider React and Vue, mainly because of their popularity and the huge resources that come with them. But before choosing the JS framework, we need to decide whether to go to the SPA architecture or monolith architecture.

After some discussion, we decided to use a monolith architecture for the MVP. Plum will use Django routing and HTML powered by Vue. When building a web application using monolithic architecture, Vue has a big advantage compared to React.

**Why Vue? **

Compare to other JS frameworks, Vue has a very useful feature called inline template

Handling Edge Cases — Vue.js

Inline template basically allows developers to use any HTML template as a Vue component template!

For example, we have about.html that was written using Django.html. We can mix and match Django code with Vue code, and it will work flawlessly

Compare when using React where you must write the HTML inside the component, the winner is clear!

Conclusion

Both frameworks have their own advantages and disadvantages. We won’t tell you Vue is better than React because it will spark endless debates. However, for the use case that we highlighted above, Vue can be a perfect solution.

Follow us on our social media Twitter or sign up to our newsletter to stay up to date with the development of Plum and other Remote work news!