全棧的自我修養: 環境搭建
Not all those who wander are lost.
彷徨者並非都迷失方向。
Table of Contents
@
當你看到這篇文章的時候,暫且認為你對如何做一個網站有了興趣.
前言
本系列文章將從一個完整的項目是如何開發的過程進行編寫,期間會涉及前端、后端和一些運維的知識。
本篇題為 全棧的自我修養
將通過一個項目整合(一前端項目對應三個后端項目
),完成一個簡單的DEMO
其中前端項目使用 Vue.js
,這個項目將會用到vue
,vuex
,vue-route
,axios
,elementUI
等
后端項目使用為 3 個項目,其中涉及Spring Boot, Mybaits, Flask
等
中間會穿插一些運維的知識如常用linux命令, Jenkins
等
也會介紹一些工具的使用
計划分為以下幾個項目:
- epimetheus-frontend 面向用戶的PC前端項目
- epimetheus-management-frontend 面向運營人員的內部管理系統前端項目
- epimetheus-miniapp-frontend 小程序前端項目
- epimetheus-backend 對應后端
- epimetheus-management-backend 對應后端
- epimetheus-miniapp-backend 對應后端
環境准備
作為第一篇,這里主要介紹Vue
環境的准備工作.
nodejs
根據實際情況下載對應版本即可
官網地址:https://nodejs.org/zh-cn/download/
安裝完成后,在控制台中輸入:node -v
即可得知安裝的node
版本,使用 npm -v
查看 npm
版本
node -v
v14.4.0
npm -v
6.14.5
vue-cli
如果上面已經驗證正確安裝了 node
和 npm
, 則使用 npm install -g vue-cli
完成 vue-cli
的安裝
創建 Vue 項目
給項目起名字一直是困擾我的第一個難題,本次將項目暫命名為 epimetheus-frontend
使用 vue-cli
命令生成項目,命令格式為:vue init webpack Vue-Project
, 這里為 vue init webpack epimetheus-frontend
,
- 首先找個存在代碼的文件夾,這里先創建一個
epimetheus
文件夾 - 進入
epimetheus
文件夾 - 執行
vue init webpack epimetheus-frontend
根據提示填寫項目信息:
? Project name epimetheus-frontend
? Project description A Vue.js project
? Author yunan.zhang <zhangyunan@91jinrong.com>
? Vue build standalone
? Install vue-router? Yes
? Use ESLint to lint your code? Yes
? Pick an ESLint preset Standard
? Set up unit tests Yes
? Pick a test runner jest
? Setup e2e tests with Nightwatch? Yes
? Should we run `npm install` for you after the project has been created? (recommended) yarn
注意上面選擇了 yarn
而不是 npm
, 這里對於使用 npm 還是 yarn, 並沒有要求,兩個的功能都能使用,只是命令略有不同而已
yarn和npm 命令 對照表
npm | yarn |
---|---|
npm install | yarn install |
(N/A) | yarn install --flat |
(N/A) | yarn install --har |
(N/A) | yarn install --no-lockfile |
(N/A) | yarn install --pure-lockfile |
npm install [package] | (N/A) |
npm install --save [package] | yarn add [package] |
npm install --save-dev [package] | yarn add [package] [--dev/-D] |
(N/A) | yarn add [package] [--peer/-P] |
npm install --save-optional [package] | yarn add [package] [--optional/-O] |
npm install --save-exact [package] | yarn add [package] [--exact/-E] |
(N/A) | yarn add [package] [--tilde/-T] |
npm install --global [package] | yarn global add [package] |
npm rebuild | yarn install --force |
npm uninstall [package] | (N/A) |
npm uninstall --save [package] | yarn remove [package] |
npm uninstall --save-dev [package] | yarn remove [package] |
npm uninstall --save-optional [package] | yarn remove [package] |
npm cache clean | yarn cache clean |
rm -rf node_modules && npm install | yarn upgrade |
安裝過程可能有點慢,安裝完成后,如下
# Project initialization finished!
# ========================
To get started:
cd epimetheus-frontend
npm run dev
Documentation can be found at https://vuejs-templates.github.io/webpack
這時,我們可以進入 epimetheus-frontend
, 並在控制台運行 npm run dev
,即可開始運行我們的項目
epimetheus$ cd epimetheus-frontend
epimetheus/epimetheus-frontend$ npm run dev
> epimetheus-frontend@1.0.0 dev /Users/zhangyunan/project/scoding/epimetheus/epimetheus-frontend
> webpack-dev-server --inline --progress --config build/webpack.dev.conf.js
13% building modules 29/31 modules 2 active ...theus/epimetheus-frontend/src/App.vue{ parser: "babylon" } is deprecated; we now treat it as { parser: "babel" }.
95% emitting
DONE Compiled successfully in 2886ms 下午1:49:57
I Your application is running here: http://localhost:8080
從控制台信息可以看出,訪問路徑為:http://localhost:8080
這樣准備工作基本就完成了
項目結構
這里使用 VSCode
進行開發,你也可以使用 Webstorm
, 兩個都可以,在使用VSCode
的時候,可以直接在終端使用 code
命令在VSCode打開執行文件或者目錄,
例如:
epimetheus/epimetheus-frontend$ code .
則會將當前文件夾 epimetheus/epimetheus-frontend
在 VSCode
中打開,
如何你安裝
VSCode
后,使用code
命令時,提示 not fund, 可以通過 查看 -> 命令面板 輸入code
進行安裝
這里使用了 VSCode
,打開項目后如圖:
├── build/ # webpack config files
│ └── ...
├── config/
│ ├── index.js # main project config
│ └── ...
├── src/
│ ├── main.js # app entry file
│ ├── App.vue # main app component
│ ├── components/ # ui components
│ │ └── ...
│ └── assets/ # module assets (processed by webpack)
│ └── ...
├── static/ # pure static assets (directly copied)
├── .babelrc # babel config
├── .editorconfig # indentation, spaces/tabs and similar settings for your editor
├── .eslintrc.js # eslint config
├── .eslintignore # eslint ignore rules
├── .gitignore # sensible defaults for gitignore
├── .postcssrc.js # postcss config
├── index.html # index.html template
├── package.json # build scripts and dependencies
└── README.md # Default README file
其中,我們主要修改 src 下文件,上面提到項目訪問端口為:8080
, 為了防止與其他項目造成沖突,這里將端口改為:7000
, 具體配置在 config/index.js
文件中
使用 elementUI
這里使用了
官網:http://element-cn.eleme.io/#/zh-CN/component/installation
這里我們進入剛才的項目目錄:並執行 yarn add element-ui
epimetheus/epimetheus-frontend$ yarn add element-ui
yarn add v1.15.2
[1/5] 🔍 Validating package.json...
[2/5] 🔍 Resolving packages...
[3/5] 🚚 Fetching packages...
[4/5] 🔗 Linking dependencies...
[5/5] 🔨 Building fresh packages...
success Saved lockfile.
success Saved 6 new dependencies.
info Direct dependencies
└─ element-ui@2.13.2
info All dependencies
├─ async-validator@1.8.5
├─ deepmerge@1.5.2
├─ element-ui@2.13.2
├─ normalize-wheel@1.0.1
├─ resize-observer-polyfill@1.5.1
└─ throttle-debounce@1.1.0
✨ Done in 8.36s.
配置
在 main.js 中寫入以下內容:
import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import App from './App.vue';
Vue.use(ElementUI);
new Vue({
el: '#app',
render: h => h(App)
});
配置完成后的 main.js 文件為:
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import App from './App'
import router from './router'
Vue.config.productionTip = false
Vue.use(ElementUI)
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
render: h => h(App),
components: { App },
template: '<App/>'
})
配置 Vuex
Vuex 是一個專為 Vue.js 應用程序開發的狀態管理模式。它采用集中式存儲管理應用的所有組件的狀態,並以相應的規則保證狀態以一種可預測的方式發生變化。Vuex 也集成到 Vue 的官方調試工具 devtools extension,提供了諸如零配置的 time-travel 調試、狀態快照導入導出等高級調試功能。
也就是通過 Vuex ,各個組件可以實時的共享狀態
官網:https://vuex.vuejs.org/zh-cn/intro.html
安裝
首先我們先安裝它 yarn add vuex
epimetheus/epimetheus-frontend$ yarn add vuex
yarn add v1.15.2
[1/5] 🔍 Validating package.json...
[2/5] 🔍 Resolving packages...
[3/5] 🚚 Fetching packages...
[4/5] 🔗 Linking dependencies...
[5/5] 🔨 Building fresh packages...
success Saved lockfile.
success Saved 1 new dependency.
info Direct dependencies
└─ vuex@3.4.0
info All dependencies
└─ vuex@3.4.0
✨ Done in 5.33s.
配置
首先在 src
下創建 store
文件夾並在其下創建 store.js
文件
即 src/store/store.js
, 同時創建 src/assets/util/cookie.js
src/assets/utils/cookie.js 文件內容
該文件主要用於操作cookie
let cookie = {
setCookie (cname, value, expiredays) {
let exdate = new Date()
exdate.setTime(exdate.getTime() + expiredays)
exdate.setDate(exdate.getDate() + expiredays)
document.cookie = cname + '=' + escape(value) + ((expiredays == null) ? '' : ';expires=' + exdate.toGMTString())
},
getCookie (name) {
let reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)')
let arr = document.cookie.match(reg)
if (arr) {
return (arr[2])
} else {
return null
}
},
delCookie (name) {
let exp = new Date()
exp.setTime(exp.getTime() - 1)
let cval = cookie.getCookie(name)
if (cval != null) {
document.cookie = name + '=; expires=Thu, 01 Jan 1970 00:00:01 GMT;'
}
}
}
export default cookie
src/store/store.js 內容
這里定義了 userInfo
用來保存當前的用戶信息,包含一個 name
和 token
import Vue from 'vue'
import Vuex from 'vuex'
import cookie from '../assets/util/cookie'
Vue.use(Vuex)
const userInfo = {
name: cookie.getCookie('name') || '',
token: cookie.getCookie('token') || ''
}
const store = new Vuex.Store({
state: {
userInfo: userInfo
},
mutations: {
setUserInfo (state) {
state.userInfo = {
name: cookie.getCookie('name'),
token: cookie.getCookie('token'),
}
}
}
})
export default store
在 main.js
添加Vuex
配置,
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import App from './App'
import router from './router'
import store from './store/store'
Vue.config.productionTip = false
Vue.use(ElementUI)
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
store,
render: h => h(App),
components: { App },
template: '<App/>'
})
配置 axios
Promise based HTTP client for the browser and node.js
axios 是一個基於 Promise 的 http client, 通過他,我們向后端進行數據交互,如果你不喜歡它,可以使用jquery
的 ajax
代替.
我們來安裝一下
epimetheus/epimetheus-frontend$ yarn add axios
yarn add v1.15.2
[1/5] 🔍 Validating package.json...
[2/5] 🔍 Resolving packages...
[3/5] 🚚 Fetching packages...
[4/5] 🔗 Linking dependencies...
[5/5] 🔨 Building fresh packages...
success Saved lockfile.
success Saved 2 new dependencies.
info Direct dependencies
└─ axios@0.19.2
info All dependencies
├─ axios@0.19.2
└─ follow-redirects@1.5.10
✨ Done in 4.39s
修改 main.js
文件
加入
import './axios_config/'
import Axios from 'axios'
Vue.prototype.$http = Axios
github
參考
- nodejs : https://nodejs.org
- vue : https://vuejs.org/
- vuex : https://vuex.vuejs.org/
- vue-route : https://router.vuejs.org/
- elementUI : http://element-cn.eleme.io/#/zh-CN/component/installation
- axios : https://github.com/axios/axios