Kickstart Your Project: Vue, Vue Router, and Vuex with TypeScript – Part 1
This article will be an introduction how to create project based on TypeScript using Vue.js and Vuex . We will start with creating application using VueCLI.
Plan of our Vue / Vue router / Vuex application
We will write simple CRUD application which will be simple :
- Getting list of posts (loading it to store)
- Creating post
- Editing post
- Removing post
Create a scaffold of Vue application
You will need to install VueCLI firstly. You can do it using NPM:
npm install -g @vue/cli
Or using Yarn:
yarn global add @vue/cli
Creating Vue application using VueCLI
What you do next is create project using VueCLI. To run this command in command line:
vue create <nameOfApp>
In my case it will be ts-vue so Im running
vue create ts-vue
data:image/s3,"s3://crabby-images/cf356/cf356f7ea0519976d67e12fdfccc0a9b74cae417" alt=""
Start defining your application using “Manually select features”:
data:image/s3,"s3://crabby-images/b2224/b22244da36b4c935b5260c174d5ae49b74e6d60e" alt=""
From menu you will need to choose options visible on screen:
data:image/s3,"s3://crabby-images/b2899/b28990009584177bd0c3842bfa5305c67999ed4a" alt=""
- Babel
- TypeScript
- Router
- Vuex
- CSS Pre-processors (it will be chosen in next steps)
- Linter / Formatter (preset will be chosen in next steps)
- Unit Testing (engine will be chosen in next steps)
- E2E Testing (engine will be chosen in next steps)
Next you will be asked about class-style components (.vue based files divided into template, script, style sections).
data:image/s3,"s3://crabby-images/954e5/954e555c41d6dee59daeb061bcb82d78cc79fc76" alt=""
Then choose your favourite pre-processor. I’ve used Stylus (why? I’ve made description in my article)
data:image/s3,"s3://crabby-images/a961d/a961d8e623f5e2b7e6dfc0007a5c2d606f4a7a62" alt=""
Next you will be asked about linters options. Use both (Lint on save and Lint and fix on commit)
data:image/s3,"s3://crabby-images/e3253/e32533f356c6dc0d86e71921b8167657bc3f87a7" alt=""
This option will add this code to package.json file
"gitHooks": {
"pre-commit": "lint-staged"
},
This is adding option which will be ran before every GIT commit. Before every commit linting operation will be ran.
Choose testing engine for both Unit testing and E2E testing:
data:image/s3,"s3://crabby-images/adebb/adebb419d368ef90ecea8c997adebfed697b5e65" alt=""
data:image/s3,"s3://crabby-images/2908e/2908e079cd2a6edc2b088e8a595f2ce7ca6d401b" alt=""
Then you will see installation process:
data:image/s3,"s3://crabby-images/683b7/683b7665a03b28eca00b2399e1ec0505b25b2989" alt=""
data:image/s3,"s3://crabby-images/71b74/71b74db901b649facbe5297839ec880d3e718947" alt=""
Vue project structure
Vue Project right after initialization with VueCLI in VisualStudio Code. As it is visible project is divided into:
- src (source of your application)
- assets
- components (here you will store components of your application)
- views (here you will store pages of your application)
- tests (tests of your application)
- public (public folder to which your application will be compiled)
data:image/s3,"s3://crabby-images/1c198/1c19897447079b05a5727832a1a9bb2db40c7037" alt=""
When you will analyse structure of src folder and look into Atomic Design pattern you can say that in components will be stored all atoms / molecules / organisms and in views pages. It looks like simplified approach of Atomic Design.
Adding PUG to Vue.js project to simplify templating
I like code minimalism thats why I like PUG (previously known as JADE). PUG is HTML preprocessor. To enable it in .VUE files we will need to follow instructions added on official Vue.js website: https://vue-loader.vuejs.org/guide/pre-processors.html#pug
npm install -D pug pug-plain-loader
You can use PUG in your templates from now on like this:
Running project
Now lest run the project!
npm run serve
And voila:
data:image/s3,"s3://crabby-images/5dd81/5dd81be7cfaf036e7bddc15a14079aab62902c0e" alt=""
Now we need to run browser with URL http://localhost:8080
(of course if we haven’t ran any other app on this port. If yes – CLI will get next free port ie. 8081, 8082 and so on)