本系列文章是爲學習Vue的項目練習筆記,儘量詳細記錄一下一個完整項目的開發過程。面向初學者,本人也是初學者,搬磚技術還不成熟。項目在技術上前端爲主,包含一些後端代碼,從基礎的數據庫(Sqlite)、到後端服務Node.js(Express),再到Web端的Vue,包含服務端、管理後臺、商城網站、小程序/App,分爲下面多個篇文檔。。
🪧系列目錄:
- 圖書商城Vue+Element+Node+TS項目練習🔗
- 圖書商城①管理後臺Vue2+ElementUI🔗
- 圖書商城②後端服務Node+Express+Sqlite🔗
- 未完成:商城網站Vue3+TS、商城APP端Vue3+TS+uniapp
- 🔸源代碼地址:Github / KWebNote,Gitee / KWebNote
- 🔸管理後端在線演示地址:http://kanding.gitee.io/kwebnote (用戶名、密碼隨意)
01、這是什麼項目?
一個很簡單的圖書商城系統,可以下單購買書籍,支持PC端、移動端訪問。因此在業務上就有多個子系統,如後臺管理系統,用來管理用戶、圖書、訂單,給管理員用;面向PC端/移動端的圖書(前臺)商城網站,面向移動端的商城App、小程序;以及後端服務和數據庫。
如下圖,包含多個子系統
🔸後端服務(server):
- 數據庫+後臺API服務,爲前臺應用提供登錄服務、文件管理服務、數據管理服務等功能。
- 採用Node+Express爲主的技術棧,數據庫使用的輕量級關係型數據庫Sqlite3。
🔸管理後臺(book_admin):
- 圖書系統的管理後臺,管理員或商家使用。提供了登錄、圖書管理、訂單管理、字典管理等各種管理功能,滿足系統的運營、管理需求。
- 採用Vue2版本爲主的技術棧,其他還包括ElementUI、vuex、vue-router、axios、echarts、i18n、less等。
🔸商城前臺(book_shop):
- 面向C端用戶的圖書商城網站,自適應PC端、移動端瀏覽器
- 進行中
🔸APP/小程序:計劃中...
02、需求分析
簡單做一個需求設計:
🔸後端服務(server):
- 文件上傳、下載,支持圖片上傳和下載。
- 登錄,驗證用戶信息並返回Token。
- 數據管理API,圖書、訂單、字典數據的增刪改查管理,及數據的存儲。
🔸管理後臺(book_admin):
- 登錄頁:用戶登錄,記住用戶名。
- 首頁:作爲默認頁面,展示系統的一些概況、用戶的一些統計信息、通知信息等。
- 圖書管理:圖書信息的增刪改查管理。
- 訂單管理:訂單的查詢、查看功能,訂單在圖書商城中用戶下單產生。
- 字典管理:字典類型、字典數據的管理,用來管理一些可變的分類數據,如圖書分類、商品促銷類型、品牌、國家、省市區地址等。
🔸圖書商城(包括網站、App/小程序):
- 登錄:用戶登錄,記住用戶名。
- 首頁:商城的首頁,顯示Logo、搜索框、商品類型、廣告,及推薦的商品圖書。
- 商品搜索列表:顯示搜索結果的商品列表。
- 商品詳情頁面:顯示商品的基本信息、詳細信息、評論信息,可以加入購物車。
- 購物車:加入購物車的商品,本地保存,可以下單。
- 個人中心:個人信息及個人訂單。
03、技術架構
而在技術上以Vue
爲主(Vue2、Vue3都有,不同子系統),UI框架Element-UI爲主。後臺服務做的比較簡單,主要是爲了滿足前端服務接口,基於Node,Express+Sqlite數據庫,Sqlite3數據庫非常的輕量,是一個比較完整的關係型數據庫,只需要安裝一個npm包即可,通過JS訪問。
雖然是一個小項目,還是畫一個技術架構圖吧:(未完...)
🔸後端服務(server):
- Node.js,開發運行環境
v16.17.1
- express,Web組件
v4.18
- sqlite3,數據庫
express.static
:靜態資源託管,express提供的,無需額外安裝。multer
:文件上傳
🔸管理後臺(book_admin):Vue v2.,ElementUI v2.
vuex
:狀態管理vue-router
:前端路由axios
:HTTP調用echarts
:圖表組件,按需定製i18n
:多語言國際化vue-i18n
v8.*版本@wangeditor
:富文本編輯器Less
:CSS預處理器/語言
🔸圖書商城網站
- Vue3,TypeScript
- //TODO
🔸App/小程序
- //TODO
04、部署
NodeJS部署
前後端部署的可以用NodeJS。
- 把前端編譯好的包放到Node目錄下,用Express的靜態文件服務中間件實現代理。
- 如果前端使用了history模式路由,則需要後端設置重定向。
//管理後臺"book_admin"的部署
//靜態資源
server.use('/bookadmin', express.static('./book_admin'));
const fs = require('fs')
const rpath = require('path')
//前端路由的重定向
server.get('/bookadmin/*', function(req, res) {
const html = fs.readFileSync(rpath.resolve(__dirname, '../server/book_admin/index.html'), 'utf-8')
res.send(html)
})
Gitee Pages部署
同Github Pages 一樣,Gitee Pages也是一個靜態WEB服務,可以用來發布一些靜態頁面,爲了網上可以預覽管理後臺網站,就用Gitee Pages部署一個。
- 因爲只能部署靜態網頁,管理後臺項目需要做一點調整:
- 項目裏後簡易的實現了一個mock,模擬一些數據。
- 修改路由模式爲hash,避免刷新後出現404錯誤。
- Gitee Page的部署比較簡單,如下圖,按照官方提示配置地址路徑即可。
05、其他
1.1、API接口封裝axios
與後端的API調用採用axios
插件,Axios 是一個基於XHR(XMLHttpRequests)支持promise 的網絡請求庫,作用於node.js 和瀏覽器中。內部是基於XHR(XMLHttpRequest)實現的(在瀏覽器中),兼容性良好,功能也比較完整。Fetch其實也不錯,是瀏覽器原生支持的HTTP調用技術,語法簡單,只是在功能上Axios要更完善一些。
基於axios
來封裝統一的API調用,主要目的:
- 全局的配置、攔截,統一配置一些請求、響應信息和處理規則。
- 統一管理所有API接口,方便mock測試。
👷♂️實現過程:
1、api.js
的封裝:統一管理API的URL地址和接口,配置代理。
// 地址配置
// 開發環境的跨域代理
const proxy = process.env.NODE_ENV === 'production' ? '' : '/server';
const URL = {
proxy: proxy,
upload: proxy + '/upload',
login: '/api/login',
book_list: '/api/book/list',
}
// 引入axios
import axios from 'axios';
//創建實例
let api = axios.create({
baseURL: proxy, //基礎URL
timeout: 9000,
});
//攔截的封裝,對請求、響應進行通用化的攔截處理
//請求攔截,可處理token、實現進度條效果
api.interceptors.request.use(function (cfg) {
return cfg;
})
// 響應攔截,可判斷響應狀態
api.interceptors.response.use(res => {
if (res.status === 200 && res.data?.status === 'OK')
return Promise.resolve(res.data);
else
return Promise.reject(res.data?.message ? res.data.message : res.status);
}, err => {
console.error(err);
return Promise.reject(err.message);
})
//接口
api.login = function (param) {
return api.post(URL.login, param);
}
api.book_list = function (param) {
return api.post(URL.book_list, param);
}
2、在main.js
引入api
:掛載到Vue原型上,就可以在Vue中全局使用了。
// 引入axios封裝的api
import api from './api/api';
// 掛載到vue上
Vue.prototype.$api = api;
調用方式:更簡潔
laodData() {
this.loading = true;
this.$api.dictype()
.then(res => {
this.dictypeList = res.data;
})
.catch(err => {
this.$message.error(err);
})
.finally(() => this.loading = false)
},
3、處理跨域,本地開發調試的時候,調用後端API肯定是要配置代理的,解決跨域問題。正式部署的時候,前端代碼和後端服務大多是部署在一塊的,就不存在跨域問題。Vue中可通過本地Node服務端來代理實現跨域,在vue.config.js
中配置需要代理的的地址。
這裏用“/server”作爲代理URL的前綴標誌,在API訪問中都需要加上這個前綴。
module.exports = defineConfig({
//基本url,多用於指定子路徑
publicPath: '/bookadmin/',
devServer: {
proxy: {
'/server': { //用 “/server” 代理 “http://localhost:3000”
target: 'http://localhost:3000', //代理的目標
changeOrigin: true,
ws: true,
pathRewrite: { '^/server': '' }
}
}
},
遇到一個401的錯誤,詳見《Vue跨域配置異常採坑:Request failed with status code 401》
1.2、vue頁面模板/片段
安裝了Vetur
插件,會自帶vue單文件的多種代碼片段模板,如下圖輸入vue就會提示,鍵盤、鼠標選擇或者回車選中第一個。
如果需要自定義片段,也很簡單,通過系統菜單>“配置用戶代碼片段”功能來配置。
如下示例,代碼片段配置是一個JSON結構配置文件,body
爲片段內容,字符數組結構。$n($1)
爲光標位置,選擇片段後,光標所在位置,如果多個則Tab
鍵切換。
"Vue": {
"prefix": "vuek",
"body": [
"<template>",
"\t$1",
"</template>",
"",
"<script>",
"export default {",
"\tdata() {",
"\t\treturn {",
"\t\t\t",
"\t\t}",
"\t},",
"\tmethods: {",
"\t\t",
"\t}",
"}",
"</script>",
"",
"<style lang='less' scoped>",
"\t",
"</style>",
],
"description": "vue頁碼模板"
}
}
參考資料:
©️版權申明:版權所有@安木夕,本文內容僅供學習,歡迎指正、交流,轉載請註明出處!原文編輯地址-語雀