# Store(参考小米商城)
## 前言
2020年寒假尤其特殊,因为新型冠状病毒肺炎疫情,学校至今没有开学。想起上学期利用课余时间学习了`Vue.js`、`Node.js`,一直想做个完整的项目实战一下,但之前在学校并没有那么多的时间。现在恰好有时间,就想着做一个项目巩固之前学到的东西。
思来想去,最后决定模仿 [小米商城 ](www.mi.com)做一个电商项目。可能时间隔得有点久了,之前学的东西很多都差不多忘记了,做这个项目基本上都是看着官方的文档一点一点做的。在家里也免不了有各种各样的事情耽误了项目的进度。现在终于差不多做好了,分享出来,新手上路,如有错误,请多多指教。
## 说明
> 本项目前后端分离,前端参考 [小米商城](www.mi.com) 实现,但与小米官方没有关系,纯属个人瞎搞,若需要购买小米产品请到小米官方商城。
> 这是本项目的前端,后端请移步到[store-server](https://github.com/hai-27/store-server) 。
> > 后端也已经部署在阿里云,接口地址已经修改为线上地址,本地运行前端也可以正常访问后端。
## 项目简介
本项目前后端分离,前端基于`Vue`+`Vue-router`+`Vuex`+`Element-ui`+`Axios`,参考小米商城实现。后端基于`Node.js(Koa框架)`+`Mysql`实现。
前端包含了11个页面:首页、登录、注册、全部商品、商品详情页、关于我们、我的收藏、购物车、订单结算页面、我的订单以及错误处理页面。
实现了商品的展示、商品分类查询、关键字搜索商品、商品详细信息展示、登录、注册、用户购物车、订单结算、用户订单、用户收藏列表以及错误处理功能。
后端采取了MVC模式,根据前端需要的数据分模块设计了相应的接口、控制层、数据持久层。后端传送地址[store-server](https://github.com/hai-27/store-server) 。
## 技术栈
- **前端:**`Vue`+`Vue-router`+`Vuex`+`Element-ui`+`Axios`
- **后端:**`Node.js`、`Koa框架`
- **数据库:**`Mysql`
## 功能模块
### 登录
页面使用了element-ui的`Dialog`实现弹出蒙版对话框的效果,`登录`按钮设置在App.vue根组件,通过`vuex`中的`showLogin`状态控制登录框是否显示。
这样设计是为了既可以通过点击页面中的按钮登录,也可以是用户访问需要登录验证的页面或后端返回需要验证登录的提示后自动弹出登录框,减少了页面的跳转,简化用户操作。
用户输入的数据往往是不可靠的,所以本项目前后端都对登录信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。
### 注册
页面同样使用了element-ui的`Dialog`实现弹出蒙版对话框的效果,`注册`按钮设置在App.vue根组件,通过父子组件传值控制注册框是否显示。
用户输入的数据往往是不可靠的,所以本项目前后端同样都对注册信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。
### 首页
首页主要是对商品的展示,有轮播图展示推荐的商品,分类别对热门商品进行展示。
### 全部商品
全部商品页面集成了全部商品展示、商品分类查询,以及根据关键字搜索商品结果展示。
### 商品详情页
商品详情页主要是对某个商品的详细信息进行展示,用户可以在这里把喜欢的商品加入购物车或收藏列表。
### 我的购物车
购物车采用vuex实现,页面效果参考了小米商城的购物车。
### 订单结算
用户在购物车选择了准备购买的商品后,点击“去结算”按钮,会来到该页面。
用户在这里选择收货地址,确认订单的相关信息,然后确认购买。
### 我的收藏
用户在商品的详情页,可以通过点击加入 喜欢 按钮,把喜欢的商品加入到收藏列表。
### 我的订单
对用户的所有订单进行展示。
## 运行项目
**注意:**
- 后端接口地址已经修改为线上的地址,本地运行会直接分为我部署在服务器的后端。
- 为了方便测试,数据库数据没有加密,注册时切记**不要使用自己的常用密码**。
- 如果需要自己运行后端,请移步到[store-server](https://github.com/hai-27/store-server) clone后端项目,并修改前端的接口地址为您的服务器地址。
```
1. Clone project
git clone https://github.com/hai-27/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
```
## 页面截图
**首页**
![](https://images.gitee.com/uploads/images/2020/0317/154615_cffbacfe_6502229.png "home.png")
**全部商品**
![](https://images.gitee.com/uploads/images/2020/0317/154637_fa50ca7a_6502229.png "goods.png")
**购物车**
![](https://images.gitee.com/uploads/images/2020/0317/154737_f0417e36_6502229.gif "shoppingCart.gif")
**我的收藏**
![](https://images.gitee.com/uploads/images/2020/0317/154717_e2baa55c_6502229.png "collect.png")
**我的订单**
![](https://images.gitee.com/uploads/images/2020/0317/154756_5813ae89_6502229.png "order.png")
**登录**
![](https://images.gitee.com/uploads/images/2020/0317/154814_27bcc9f1_6502229.png "login.png")
**注册**
![](https://images.gitee.com/uploads/images/2020/0317/154827_2399157d_6502229.png "register.png")
没有合适的资源?快使用搜索试试~ 我知道了~
基于vue+vue-router+vuex+element-ui+axios,参考小米商城,实现的电商项目,仿小米商城源代码
共95个文件
png:23个
js:20个
vue:15个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
5星 · 超过95%的资源 14 下载量 50 浏览量
2022-12-26
15:46:20
上传
评论 8
收藏 11.5MB ZIP 举报
温馨提示
本项目前后端分离,前端基于`Vue`+`Vue-router`+`Vuex`+`Element-ui`+`Axios`,参考小米商城实现。后端基于`Node.js(Koa框架)`+`Mysql`实现。 前端包含了11个页面:首页、登录、注册、全部商品、商品详情页、关于我们、我的收藏、购物车、订单结算页面、我的订单以及错误处理页面。 实现了商品的展示、商品分类查询、关键字搜索商品、商品详细信息展示、登录、注册、用户购物车、订单结算、用户订单、用户收藏列表以及错误处理功能。 后端采取了MVC模式,根据前端需要的数据分模块设计了相应的接口、控制层、数据持久层。
资源推荐
资源详情
资源评论
收起资源包目录
vue-store-master.zip (95个子文件)
vue-store-master
.browserslistrc 21B
babel.config.js 73B
.eslintrc.js 381B
.gitattributes 66B
src
App.vue 9KB
store
modules
user.js 738B
shoppingCart.js 5KB
index.js 388B
assets
logo.png 7KB
css
index.css 1KB
github-markdown.css 16KB
imgs
error.png 91KB
logo.png 6KB
us-icon.png 3KB
cart-empty.png 32KB
github.png 4KB
main.js 3KB
components
MyList.vue 4KB
MyRegister.vue 5KB
MyMenu.vue 1KB
Error.vue 411B
MyLogin.vue 4KB
MyMarkdown.vue 852B
router
index.js 2KB
Global.js 722B
views
ConfirmOrder.vue 11KB
Goods.vue 7KB
Collect.vue 2KB
ShoppingCart.vue 11KB
Details.vue 9KB
Order.vue 7KB
Home.vue 7KB
About.vue 1KB
dist
screenshots
shoppingCart.png 101KB
login.png 276KB
goods.png 666KB
register.png 275KB
home.png 1.48MB
shoppingCart.gif 1.73MB
order.png 160KB
collect.png 295KB
js
chunk-e6ee55e4.5663226f.js 542KB
chunk-31f8af38.63588a6c.js 3KB
chunk-31f8af38.63588a6c.js.map 17KB
chunk-6c0851c2.6f13a894.js.map 2KB
chunk-6128cc72.06bfde5c.js.map 24KB
chunk-55adf198.2ab05ebc.js 6KB
chunk-207d675a.9ef791fa.js 5KB
chunk-0b860ded.1f10e81b.js 1KB
chunk-5dbc91e2.8fd907d9.js.map 23KB
chunk-0b860ded.1f10e81b.js.map 7KB
chunk-102fa6c7.9d737f96.js.map 17KB
chunk-e6ee55e4.5663226f.js.map 1.58MB
app.6d64d836.js.map 93KB
chunk-207d675a.9ef791fa.js.map 20KB
chunk-6c0851c2.6f13a894.js 566B
chunk-102fa6c7.9d737f96.js 4KB
chunk-vendors.614d785b.js.map 3.31MB
chunk-vendors.614d785b.js 847KB
chunk-6128cc72.06bfde5c.js 5KB
chunk-55adf198.2ab05ebc.js.map 24KB
app.6d64d836.js 23KB
chunk-5dbc91e2.8fd907d9.js 6KB
img
cart-empty.8b316431.png 32KB
error.73de3ae8.png 91KB
logo.c8999c02.png 6KB
css
chunk-vendors.d39e9fad.css 228KB
chunk-0b860ded.e011a452.css 724B
chunk-6c0851c2.41d025c7.css 142B
chunk-102fa6c7.e30051ac.css 1012B
chunk-5dbc91e2.a42fe968.css 4KB
chunk-6128cc72.b3452ebd.css 5KB
chunk-e6ee55e4.b670c1eb.css 14KB
chunk-207d675a.0d974836.css 2KB
chunk-55adf198.f132a057.css 854B
app.03996341.css 12KB
chunk-31f8af38.09f7d5e3.css 3KB
favicon.ico 4KB
index.html 2KB
fonts
element-icons.535877f5.woff 28KB
element-icons.732389de.ttf 55KB
package.json 747B
public
screenshots
shoppingCart.png 101KB
login.png 276KB
goods.png 666KB
register.png 275KB
home.png 1.48MB
shoppingCart.gif 1.73MB
order.png 160KB
collect.png 295KB
favicon.ico 4KB
index.html 547B
package-lock.json 428KB
vue.config.js 499B
README.md 5KB
共 95 条
- 1
Python代码大全
- 粉丝: 2727
- 资源: 689
下载权益
C知道特权
VIP文章
课程特权
开通VIP
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
- 1
- 2
- 3
- 4
- 5
前往页