技术栈概述

Node.js作为后端运行时环境,Vue.js构建前端交互界面,ElementUI提供UI组件库,Express框架处理后端逻辑,MySQL存储药品及订单数据。系统支持药品分类展示、购物车管理、在线支付及订单追踪功能。

系统架构设计

采用前后端分离架构,前端通过Vue CLI初始化项目,后端使用Express搭建RESTful API。数据库设计包含药品表(drugs)、用户表(users)、订单表(orders)及购物车表(cart),通过Sequelize ORM实现模型关联。

核心功能实现

药品管理模块

  • 药品分类查询:通过/api/drugs/category接口按分类筛选,前端使用ElementUI的<el-select>绑定分类参数。
  • 药品搜索功能:后端使用MySQL的LIKE语句实现模糊查询,Vue前端通过v-model绑定搜索关键词。

购物车与订单模块

  • 购物车持久化:用户登录后,通过localStorage临时存储未登录状态下的购物项,登录后同步至数据库。
  • 订单生成流程:调用/api/orders/create接口,后端验证库存后生成订单,返回支付链接。

关键技术实现

Express后端示例

// 药品列表接口
app.get('/api/drugs', async (req, res) => {
  const { category, keyword } = req.query;
  const whereClause = {};
  if (category) whereClause.category = category;
  if (keyword) whereClause.name = { [Op.like]: `%${keyword}%` };
  const drugs = await Drug.findAll({ where: whereClause });
  res.json(drugs);
});

Vue前端组件示例

<template>
  <el-table :data="drugList">
    <el-table-column prop="name" label="药品名称"></el-table-column>
    <el-table-column prop="price" label="价格"></el-table-column>
  </el-table>
</template>
<script>
export default {
  data() {
    return { drugList: [] };
  },
  async created() {
    const res = await axios.get('/api/drugs');
    this.drugList = res.data;
  }
};
</script>

数据库设计要点

  • 药品表(drugs):包含idnamepricestockcategory字段,设置索引优化查询。
  • 订单表(orders):关联用户ID与药品ID,记录status(待支付/已发货)及total_amount

部署与优化

  • 使用PM2管理Node.js进程,Nginx反向代理前端静态文件及API请求。
  • 数据库优化:通过Redis缓存热门药品查询结果,减少MySQL压力。

安全与扩展

  • JWT实现用户认证,敏感接口增加权限中间件。
  • 扩展方向:集成第三方支付(如支付宝API)、药品库存预警功能。
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

–nodejs技术栈–

后端使用nodejs来搭建服务器
Vue.js 是一款渐进式 JavaScript 框架,专注于构建用户界面。它具有轻量级的特点,代码简洁高效,能够快速加载和运行,为用户提供流畅的交互体验。Vue 采用组件化开发模式,开发者可以将页面拆分成一个个独立的组件,每个组件都有自己的 HTML、CSS 和 JavaScript 代码,实现了高度的复用性和可维护性。其数据绑定和响应式系统设计巧妙,当数据发生变化时,页面会自动更新,反之亦然,极大地简化了前端开发中数据与视图同步的复杂操作。

前端:Vue和ElementUI
数据库:mysql
框架:Express或者koa
数据库工具:Navicat/SQLyog都可以
开发运行软件:VScode/webstorm/hbuiderx均可
Node被初学者会误以为是一种语言,其实node.js是使得JavaScript能在服务端运行的平台,使得 JavaScript 能像其它的后台语言一样可以操作网络、系统等。它的产生是由于Ryan Dahl认为I/O处理地不好,会因为同步执行造成代码阻塞,以前传统的Web服务技术是对每一个请求都启动一个线程进行处理。
MySQL 是关系型数据库管理系统的代表, 因为MySQL是其免费开源的,而且MySQL的功能已经足够用对于学习和中小型企业来讲,所以开发中小型网站都会选择MySQL作为网站的数据库。[13]

结论

毕设项目前端使用vue框架,后端使用js的node,满足用户的讯息接受,信息搜索,资讯查看的操作。
前端使用web技术html、css、js等Vue.js进行静态网页开发。做到基础的框架设计以及css定位。
后端使用mysql+node.js进行开发。对后台的数据可进行增删改查。方便管理后台数据。

  1. 通过阅读官网文档、观看老师提供的教学视频,再结合实践项目案例以及相关书籍,学习掌握相关核心知识和技术。
  2. 使用axios网络请求库等工具,实现前后端数据的交互。
  3. 通过数据库,将不同的数据进行规划整理,设计出较为高效的方案。
  4. 在设计网站过程中,注重页面的加载速度,界面美观度,交互的流畅性等。

源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!

需要成品或者定制,加我们的时候,不满意的可以定制
文章最下方名片联系我即可~ 所有项目都经过测试完善,本系统包修改时间和标题,包安装部署运行调试

Logo

电商企业物流数字化转型必备!快递鸟 API 接口,72 小时快速完成物流系统集成。全流程实战1V1指导,营造开放的API技术生态圈。

更多推荐