主頁 > 企業開發 > 圖書商城Vue+Element+Node專案練習(...)

圖書商城Vue+Element+Node專案練習(...)

2023-06-29 08:54:51 企業開發

image.png

本系列文章是為學習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、小程式;以及后端服務和資料庫,

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頁碼模板"
}
}

參考資料:

  • Vue 官方檔案
  • element-ui
  • Express 中文網
  • vue-element-admin vue2的版本后臺框架
  • Git入門圖文教程(1.5W字40圖)??

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

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/556252.html

標籤:其他

上一篇:記錄--不定高度展開收起影片 css/js 實作

下一篇:返回列表

標籤雲
其他(161823) Python(38259) JavaScript(25516) Java(18273) C(15238) 區塊鏈(8273) C#(7972) AI(7469) 爪哇(7425) MySQL(7271) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5875) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4607) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1985) HtmlCss(1976) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1881) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 圖書商城Vue+Element+Node專案練習(...)

    本系列文章是為學習Vue的專案練習筆記,盡量詳細記錄一下一個完整專案的開發程序。面向初學者,本人也是初學者,搬磚技識訓不成熟。專案在技術上前端為主,包含一些后端代碼,從基礎的資料庫(Sqlite)、到后端服務Node.js(Express),再到Web端的Vue,包含服務端、管理后臺、商城網站、小程... ......

    uj5u.com 2023-06-29 08:54:51 more
  • 記錄--不定高度展開收起影片 css/js 實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 不定高度展開收起影片 最近在做需求的時候,遇見了元素高度展開收起的影片需求,一開始是想到了使用 transition: all .3s; 來做影片效果,在固定高度的情況下,transition 影片很好使,滿足了需求,但是如果要考慮之后可 ......

    uj5u.com 2023-06-29 08:54:35 more
  • 前端打包部署后介面BASE_URL不對問題解決辦法

    在前端打包部署時,為了免去不同環境打包的麻煩,專案用的流水線觸發方式。在這里不細說,重點說說下面情況。 當專案提交打包部署后,訪問壓測環境或者生產環境的地址來使用專案時,發現介面報錯404。 在NETWORK里發現介面的BASEURL和當前環境需要呼叫的后端baseurl不同。 主要問題在于配置問題 ......

    uj5u.com 2023-06-29 08:54:22 more
  • this指向性問題

    this的查找規則會逐層往上查找,最終位全域window 優先級問題:顯式系結(顯式系結與new系結沒有可比性)new系結>隱式系結>默認系結 在編程中,this 是一個關鍵字,代表當前物件或者函式的執行環境。this 的指向性問題是指在不同的情況下,this 指向的物件不同,從而影響代碼的行為。 ......

    uj5u.com 2023-06-29 08:54:12 more
  • this指向性問題

    this的查找規則會逐層往上查找,最終位全域window 優先級問題:顯式系結(顯式系結與new系結沒有可比性)new系結>隱式系結>默認系結 在編程中,this 是一個關鍵字,代表當前物件或者函式的執行環境。this 的指向性問題是指在不同的情況下,this 指向的物件不同,從而影響代碼的行為。 ......

    uj5u.com 2023-06-29 08:48:10 more
  • Vue2.0針對設備調節顯示內容方法

    一晚上完成0.2.2、0.3.0、0.3.1三個版本的更新,很高興,總結一下 專案地址: [穆音博客](https://blog.muvocal.com) 文章首發地址:[Vue針對設備調節顯示](https://blog.muvocal.com/blog/11) ## Vue中進行優化的方式 總體 ......

    uj5u.com 2023-06-28 10:04:15 more
  • React ISR 如何實作 - 最后的 Demo

    之前寫了兩個 `demo` 講解了如何實作 `SSR` 和 `SSG`,今天再寫個 `demo` 說在 `ISR` 如何實作。 ## 什么是 ISR `ISR` 即 `Incremental Static Regeneration` 增量靜態再生,是指在 `SSG` 的前提下,可以在收到請求時判定頁 ......

    uj5u.com 2023-06-28 10:04:10 more
  • 618技術揭秘:探究競速榜頁面核心前端技術

    本文將探究京東競速榜H5頁面的核心前端技術,包括影片、樣式配置化、皮膚切換、海報技術、除錯技巧等方面,希望能夠為廣大前端開發者提供一些有用的參考和思路。 ......

    uj5u.com 2023-06-28 10:04:04 more
  • 前端檔案上傳的幾種互動造輪子

    前端檔案上傳本來是一個常規互動操作,沒什么特殊性可言,但是最近在做檔案上傳,需要實作截圖粘貼上傳,去找了下有沒有什么好用的組件,網上提供的方法有,但是沒找完整的組件來支持cv上傳,經過了解發現可以用剪貼板功能讓自己的cv實作檔案上傳,于是自己就整合了目前幾種檔案上傳的互動方式,碼了一個支持cv的vu... ......

    uj5u.com 2023-06-28 10:03:59 more
  • 記錄--Threejs-著色器實作一個水波紋

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 hree.js 是一個基于 WebGL 的 JavaScript 3D 庫,用于創建和渲染 3D 圖形場景。 一、 影像渲染程序 1、webGL webGL: WebGL 是一種基于 JavaScript API 的圖形庫,它允許在瀏覽器 ......

    uj5u.com 2023-06-28 09:58:41 more