计算机毕业设计 | vue+node.js(Koa) 小米商城 前后端分离手机购物平台(附源码)
1项目简介本项目前后端分离前端基于VueVue-routerVuexElement-uiAxios参考小米商城实现。后端基于Node.js(Koa框架)Mysql实现。前端包含了11个页面首页、登录、注册、全部商品、商品详情页、关于我们、我的收藏、购物车、订单结算页面、我的订单以及错误处理页面。实现了商品的展示、商品分类查询、关键字搜索商品、商品详细信息展示、登录、注册、用户购物车、订单结算、用户订单、用户收藏列表以及错误处理功能。后端采取了MVC模式根据前端需要的数据分模块设计了相应的接口、控制层、数据持久层。2技术栈后端技术技术说明官网Node.JSJS代码的运行环境https://nodejs.org/enExpressWeb应用开发框架https://www.expressjs.com.cn/Express-sessionsession的中间件 有源码 获取源码EJS嵌入式模板引擎https://ejs.bootcss.com/Morgan日志中间件https://github.com/jwtk/jjwtMulter表单数据处理工具https://github.com/expressjs/multerMySQL数据库https://www.mysql.com/前端技术技术说明官网Vue前端框架https://vuejs.org/Vue-router路由框架https://router.vuejs.org/Vuex全局状态管理框架https://vuex.vuejs.org/Element前端UI框架https://element.eleme.ioAxios前端HTTP框架https://github.com/axios/axiosv-charts基于Echarts的图表框架https://v-charts.js.org/3功能模块3.1 登录页面使用了element-ui的Dialog实现弹出蒙版对话框的效果登录按钮设置在App.vue根组件通过vuex中的showLogin状态控制登录框是否显示。这样设计是为了既可以通过点击页面中的按钮登录也可以是用户访问需要登录验证的页面或后端返回需要验证登录的提示后自动弹出登录框减少了页面的跳转简化用户操作。用户输入的数据往往是不可靠的所以本项目前后端都对登录信息进行了校验前端基于element-ui的表单校验方式自定义了校验规则进行校验。3.2 注册页面同样使用了element-ui的Dialog实现弹出蒙版对话框的效果注册按钮设置在App.vue根组件通过父子组件传值控制注册框是否显示。用户输入的数据往往是不可靠的所以本项目前后端同样都对注册信息进行了校验前端基于element-ui的表单校验方式自定义了校验规则进行校验。3.3 首页首页主要是对商品的展示有轮播图展示推荐的商品分类别对热门商品进行展示。3.4 全部商品全部商品页面集成了全部商品展示、商品分类查询以及根据关键字搜索商品结果展示。3.5 商品详情页商品详情页主要是对某个商品的详细信息进行展示用户可以在这里把喜欢的商品加入购物车或收藏列表。3.6 我的购物车购物车采用vuex实现页面效果参考了小米商城的购物车。3.7 订单结算用户在购物车选择了准备购买的商品后点击“去结算”按钮会来到该页面。用户在这里选择收货地址确认订单的相关信息然后确认购买。3.8 我的收藏用户在商品的详情页可以通过点击加入 喜欢 按钮把喜欢的商品加入到收藏列表。3.9 我的订单对用户的所有订单进行展示。项目编码01-02-06