# vue-store-serve **Repository Path**: yindj/vue-store-serve ## Basic Information - **Project Name**: vue-store-serve - **Description**: node+koa2+koa-router+MySQL - **Primary Language**: NodeJS - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2021-06-28 - **Last Updated**: 2021-07-29 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 仿小米商城 ## 前言 2021年,身边发生了太多的事情刺激着我的内心深处,决定自己动手搞一个前端+后端的项目。光有想法是不靠谱的,要付诸行动,代码撸起来。 ## 说明 > 本项目前后端分离,前端参考 [小米商城](www.mi.com) 实现。 ## 项目简介 本项目前后端分离,前端基于`Vue`+`Vue-router`+`Vuex`+`Element-ui`+`Axios`,参考小米商城实现。后端基于`Node.js(Koa框架)`+`Mysql`实现。 前端包含了11个页面:首页、登录、注册、全部商品、商品详情页、关于我们、我的收藏、购物车、订单结算页面、我的订单以及错误处理页面。 实现了商品的展示、商品分类查询、关键字搜索商品、商品详细信息展示、登录、注册、用户购物车、订单结算、用户订单、用户收藏列表以及错误处理功能。 后端采取了MVC模式,根据前端需要的数据分模块设计了相应的接口、控制层、数据持久层。 ## 技术栈 - **前端:**`Vue`+`Vue-router`+`Vuex`+`Element-ui`+`Axios` - **后端:**`Node.js`、`Koa2`、`Koa-router` - **数据库:**`Mysql`、`Redis` ## 功能模块 ### 登录 页面使用了element-ui的`Dialog`实现弹出蒙版对话框的效果,`登录`按钮设置在App.vue根组件,通过`vuex`中的`showLogin`状态控制登录框是否显示。 这样设计是为了既可以通过点击页面中的按钮登录,也可以是用户访问需要登录验证的页面或后端返回需要验证登录的提示后自动弹出登录框,减少了页面的跳转,简化用户操作。 用户输入的数据往往是不可靠的,所以本项目前后端都对登录信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。 ### 注册 页面同样使用了element-ui的`Dialog`实现弹出蒙版对话框的效果,`注册`按钮设置在App.vue根组件,通过父子组件传值控制注册框是否显示。 用户输入的数据往往是不可靠的,所以本项目前后端同样都对注册信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。 ### 首页 首页主要是对商品的展示,有轮播图展示推荐的商品,分类别对热门商品进行展示。 ### 全部商品 全部商品页面集成了全部商品展示、商品分类查询,以及根据关键字搜索商品结果展示。 ### 商品详情页 商品详情页主要是对某个商品的详细信息进行展示,用户可以在这里把喜欢的商品加入购物车或收藏列表。 ### 我的购物车 购物车采用vuex实现。 ### 订单结算 用户在购物车选择了准备购买的商品后,点击“去结算”按钮,会来到该页面。 用户在这里选择收货地址,确认订单的相关信息,然后确认购买。 ### 我的收藏 用户在商品的详情页,可以通过点击加入 喜欢 按钮,把喜欢的商品加入到收藏列表。 ### 我的订单 对用户的所有订单进行展示。 ## 运行项目 **注意:** - 后端接口地址已经修改为线上的地址,本地运行会直接分为我部署在服务器的后端。 - 为了方便测试,数据库数据没有加密,注册时切记**不要使用自己的常用密码**。 ``` 1. Clone project git clone https://github.com/ydj/vue-store.git 2. Project setup cd vue-store npm install 3. Compiles and hot-reloads for development npm run serve 4. Compiles and minifies for production npm run build ``` **作者** [ydj](https://blog.csdn.net/qq_36818627?spm=1000.2115.3001.5343)