Rewriting my website using Vue

I finally started fiddling with Vue in my free time and I'm happy to say I've fallen in love with this framework.

I'll go over the things I've learned and the changes I've had to implement in order to rewrite my website from Angular to Vue.

Step 1: Understanding the framework

Vue is well known for being easy to use at first, and coming from an Angular background, the concepts were not that hard to understand.

I knew I wanted to have an overview of the whole ecosystem (or at least the most well known elements of it), namely:

  • Vue
  • Vuex
  • Vue-router

After digging around, I found multiple tutorials explaining these concepts in detail: state management, routing, Vue 2 and started coding a cost management application.

Nothing too fancy, it simply allowed me to understand component management via the multiple boxes and elements of my interface and state management via the management of prices and their mutation.

Step 2: Rewriting

After hearing lots of good things over the performance of Vue, I wanted to take advantage of it by rewriting my personal website. This would allow me to understand the necessary changes for transitioning from an Angular to a Vue project and would allow me to fix multiple design issues.

First things first, I had to initialize my project:

# install vue-cli
$ npm install --global vue-cli
# create a new project using the "webpack" template
$ vue init webpack
# install dependencies and go!
$ cd
$ npm install
$ npm run dev

I now have an up and running Vue project and want to understand what will be needed in the near future:

  • Multiple components
    • App (base component)
    • Navigation
    • Home
    • Work
    • Posts
    • Side (for the side text with my title, not truly necessary but useful).
  • Routing
    • '/' → Home
    • '/work' → Work
    • '/posts' → Posts
    • '*' → Home

Therefore, my root component's (App) template was as follows:

  <div id="app">
    <!-- Navigation -->
    <navigation />
    <!-- Side text -->
    <!-- Content container (grey area) -->
    <div class="content">
        <!-- Router -->

With multiple changes here and there, such as centralizing my styles, templates and scripts into single .vue files and changing my *ngFors and ngIfs into v-for and v-ifs I had a finished product with little to no problems.

Both websites were identical with one exception: Vue's performance was notable.

Final thoughts

It has been a pleasure learning the ways of VueJS, and I will surely keep on using and learning this framework in the future.

I've enjoyed multiple aspects of Vue:

  • Having a single file per component
  • Actually using JS and not JSX (I'm looking at you React)
  • The ease of use of its router
  • The use of a store to manage states
  • Vue-CLI
  • And many other little things that make the development process a pleasure.

Thanks for reading,