Nkem's Tech Teachings

27 Oct 2023 . 8 min read

Start a Vue 3 Project from Scratch

VueJS is a progressive JavaScript framework that makes building modern web applications a breeze. With a good UI framework like Vuetify and a build tool like Vite, building web apps becomes even breezier.

There are readily available templates and commands to build your Vue App and if you are interested in a quick and easy start you can check out the Quick Start Vuetify Project. However, there are merits to creating your Vue Project from scratch, you can gain insights into the framework itself, as well as insight on your project architecture and the underlying intricacies of the Vue Ecosystem. It's great for those who want to learn every detail or make their app just right for their needs.

Starting a Vue project from scratch may seem tricky, but with the right guidance, it can be a rewarding and straightforward process. In this blog post, I will take you through the essential steps to start your Vue project from the ground up with Vuetify and Vite. By the end of this guide, you will have a solid foundation for creating dynamic and interactive web applications using VueJS.

Prerequisites

Before diving into your project, you have to ensure that you have the necessary tools ready. For this project you will need :

  • A command line interface / terminal
  • A code editor (like VS Code or WebStorm)
  • NodeJS installed

If you're new to web devolpment and need guidance setting up everything I recommend starting with my tutorial for Getting Started with Web Development. Once you have completed the initial set up, you can return here and dive into creating your Vue project from scratch.

Step 1: Initialize your Project

First, create a new folder on your computer where you would like your project to go. Then you can open up the folder in your IDE, for the purpose of this tutorial we will be using an IDE called Visual Studio Code. In Visual Studio Code, once you open up the project folder you created, you can go to the terminal and initialize the project using the command :

            npm init -y

      

This command creates a file called package.json in your project directory, and we will need to edit the file to get your project up and running properly.

Step 2: Edit Package.json

The package.json is a fundamental file for any Node.js based projects, including those that use frameworks and libraries like Vue, React, Angular, and many others. For the purpose of our project, we need to add some modifications to ensure compatibility and optimization for a Vue + Vite setup.

First, remove lines :

package.json
            "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },

      

This is because our project isn't a typical Node app, and this keeps things simple and clear.

Next, we need to add the variable "private": true to make sure our project isn't accidentally published to the NPM registry.

Then, we will need to include scripts so that our application can run.

Add the following code to your package.json after the description variable to implement this:

package.json
              {
        /* existing code ... */

        "private": true,
        "scripts": {
            "dev": "vite",
            "build": "vite build",
            "preview": "vite preview",
            "lint": "eslint . --fix --ignore-path .gitignore"
        },

        /* existing code ... */
    }

      

Step 3: Install Dependencies and SetUp Plugins

Now we need to add the essential dependencies for our project. Use the following commands to install :

            npm i vue vuetify @mdi/font

      
            npm install -D sass vite @vitejs/plugin-vue vite-plugin-vuetify

      

You will notice a node_modules folder appear in your directory.

Now we need to create a folder called src, think of the src folder as the place where all the important code for your website or web app lives.

Inside the src folder, create a folder called plugins. Since we are using the UI framework, Vuetify for our project, we will need to add some setup information and additional styling or functionality for our project.

Under the plugins folder create a file called vuetify.js. Within this file add the following code :

src/plugins/vuetify.js
              import { createVuetify } from 'vuetify'

    // Styles
    import '@mdi/font/css/materialdesignicons.css'
    import 'vuetify/styles'

    export default createVuetify({
        theme: {
          themes: {
            light: {
              colors: {
                primary: '#1867C0',
                secondary: '#5CBBF6',
              },
            },
          },
        },
      })

      

Next, create a file called index.js, still inside the plugins folder. This file plays a crucial role in configuring and registering various plugins for your Vue application:

/src/plugins/index.js
              import vuetify from './vuetify'

    export function registerPlugins (app) { 
        app.use(vuetify)
    }

      

Step 4: SetUp Vite Config

Next you'll have to create a file called vite.config.js, in the root of your project, outside the src folder.

Vite empowers you with greater control over your project's configuration through the use of a config file, vite.config.js.

Open the vite.config.js file in your editor.

In this file we get to define the plugins we'll need to set up Vue and our UI framework, Vuetify.

For a basic setup, you can start with the following structure:

vite.config.js
            // Plugins
    import vue from '@vitejs/plugin-vue'
    import vuetify, { transformAssetUrls } from 'vite-plugin-vuetify'

    // Utilities
    import { defineConfig } from 'vite'

    export default defineConfig({
        plugins: [

            /** handle vuejs configurations */
            vue({
                template: { transformAssetUrls }
            }),

            /** add vuetify ui framework into project */
            vuetify({
                autoImport: true
            }),
        ]
    })

      

Vite provides a host of other configuration options like build, css, aliases and more. Depending on your project's needs, you might want to look into the official vite documentation to explore and implement them.

Step 5 : Create index.html file

Your Vue app needs an HTML entry point. We'll create an index.html file in the project root, where your Vue application will be mounted.

index.html
            <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <link rel="icon" href="/favicon.ico" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Hello World</title>
      </head>

      <body>
        <div id="app"></div>
        <script type="module" src="/src/main.js"></script>
      </body>
    </html>

      

By following these steps, you'll have your index.html file ready as the entry point for your Vue app, next we will need a folder to store assets like the favicon, enhancing the appearance and functionality of your web application.

Step 6: Create public folder

The public folder is used to store static assets that don't need processing or bundling like images or fonts. In your project root create a folder called public.

In our public folder, we'll save an image and name it favicon.ico, this is the small icon you usually see next to the website title in browser tabs or bookmarks. You can use this image as your icon, alternatively you can choose your own favicon image online

Step 7: Create the Vue App

We are finally ready to create the core structure of our Vue App.

Navigate to your src folder, inside this folder we will add in our core structure.

Begin by creating a file called App.vue in the project root directory, this is our main Vue component. Most of what you see in a Vue app starts from this component and other components branch out from it.

src/app.vue
            <template>
    <h1> Hello World </h1>
  </template>

  <script setup>
    //
  </script>

      

Next, we'll create a file called main.js. This file serves as the entry point for our Vue App, it helps set the stage for our application.

src/main.js
            // Components
    import App from './App.vue'

    // Composables
    import { createApp } from 'vue'

    // Plugins
    import { registerPlugins } from '/src/plugins'

    const app = createApp(App)

    registerPlugins(app)

    app.mount('#app')

      

With these steps completed, your Vue project structure is taking shape, and you're all set to embark on your web development journey with Vue and Vuetify.

At the end your file structure should look something like this :

            /project-root
    ├── /node_modules
    ├── /public
   └── favicon.ico
    ├── /src
   ├── App.vue
   ├── main.js
   └── /plugins
       └── index.js
       └── vuetify.js
    ├── vite.config.js
    ├── package.json
    └── index.html

      

Step 8: Run App

Now it's time to see your Vue App in action. Run the command

            npm run dev

      

or

            yarn dev

      

Once you run the command, you'll see an output in your terminal that resembles the following:

mainImg

If you copy the URL into your web browser, you'll see your Vue app live in your browser

Conclusion

Starting your Vue App from scratch is great to familiarize yourself with the programming language, but if you want a quick and easy start to your project and to build something fun, quickly, check out my other article :

Frontend Development: ReCreate the Opening of Marvel's Secret Invasion Website using VueJS and Vuetify

Sources :

Intro to Vue

Get Started with Vue - FreeCodeCamp

Yarn Installation Tutorial.

Downloading and Installing Node / NPM