圖書商城Vue+Element+Node項目練習(...)

image.png

本系列文章是爲學習Vue的項目練習筆記,儘量詳細記錄一下一個完整項目的開發過程。面向初學者,本人也是初學者,搬磚技術還不成熟。項目在技術上前端爲主,包含一些後端代碼,從基礎的數據庫(Sqlite)、到後端服務Node.js(Express),再到Web端的Vue,包含服務端、管理後臺、商城網站、小程序/App,分爲下面多個篇文檔。。

🪧系列目錄

01、這是什麼項目?

一個很簡單的圖書商城系統,可以下單購買書籍,支持PC端、移動端訪問。因此在業務上就有多個子系統,如後臺管理系統,用來管理用戶、圖書、訂單,給管理員用;面向PC端/移動端的圖書(前臺)商城網站,面向移動端的商城App、小程序;以及後端服務和數據庫。

image.png

image.png

如下圖,包含多個子系統

🔸後端服務(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-i18nv8.*版本
  • @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的部署比較簡單,如下圖,按照官方提示配置地址路徑即可。

image.png

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就會提示,鍵盤、鼠標選擇或者回車選中第一個。

image.png

如果需要自定義片段,也很簡單,通過系統菜單>“配置用戶代碼片段”功能來配置。

image.png

如下示例,代碼片段配置是一個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頁碼模板"
}
}

參考資料:


©️版權申明:版權所有@安木夕,本文內容僅供學習,歡迎指正、交流,轉載請註明出處!原文編輯地址-語雀

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章