Giter Site home page Giter Site logo

hai-27 / vue-store Goto Github PK

View Code? Open in Web Editor NEW
1.1K 1.1K 268.0 16.53 MB

基于Vue+Vue-Router+Vuex+Element-ui+axios,参考小米商城,实现的电商项目。

Home Page: http://8.141.3.248

JavaScript 11.01% HTML 0.47% Vue 72.81% CSS 15.70%
axios element-ui vue vue-router vuex

vue-store's Introduction

Store(参考小米商城)

前言

2020年寒假尤其特殊,因为新型冠状病毒肺炎疫情,学校至今没有开学。想起上学期利用课余时间学习了Vue.jsNode.js,一直想做个完整的项目实战一下,但之前在学校并没有那么多的时间。现在恰好有时间,就想着做一个项目巩固之前学到的东西。

思来想去,最后决定模仿 小米商城 做一个电商项目。可能时间隔得有点久了,之前学的东西很多都差不多忘记了,做这个项目基本上都是看着官方的文档一点一点做的。在家里也免不了有各种各样的事情耽误了项目的进度。现在终于差不多做好了,分享出来,新手上路,如有错误,请多多指教。

说明

本项目前后端分离,前端参考 小米商城 实现,但与小米官方没有关系,纯属个人瞎搞,若需要购买小米产品请到小米官方商城。

这是本项目的前端,后端请移步到store-server

前端已经部署在阿里云,欢迎访问 http://101.132.181.9/ (没有兼容移动端,请使用电脑访问)。

后端也已经部署在阿里云,接口地址已经修改为线上地址,本地运行前端也可以正常访问后端。

本人在读本科大三,今年暑假即将开始实习,后面的时间可能没有那么的自由,但会不定期的更新完善该项目,如有问题请直接在 Issues 中提。

如果觉得这个项目还不错,您可以点右上角 Star支持一下, 谢谢! ^_^

项目简介

本项目前后端分离,前端基于Vue+Vue-router+Vuex+Element-ui+Axios,参考小米商城实现。后端基于Node.js(Koa框架)+Mysql实现。

前端包含了11个页面:首页、登录、注册、全部商品、商品详情页、关于我们、我的收藏、购物车、订单结算页面、我的订单以及错误处理页面。

实现了商品的展示、商品分类查询、关键字搜索商品、商品详细信息展示、登录、注册、用户购物车、订单结算、用户订单、用户收藏列表以及错误处理功能。

后端采取了MVC模式,根据前端需要的数据分模块设计了相应的接口、控制层、数据持久层。后端传送地址store-server

技术栈

  • 前端:Vue+Vue-router+Vuex+Element-ui+Axios

  • 后端:Node.jsKoa框架

  • 数据库:Mysql

功能模块

登录

页面使用了element-ui的Dialog实现弹出蒙版对话框的效果,登录按钮设置在App.vue根组件,通过vuex中的showLogin状态控制登录框是否显示。

这样设计是为了既可以通过点击页面中的按钮登录,也可以是用户访问需要登录验证的页面或后端返回需要验证登录的提示后自动弹出登录框,减少了页面的跳转,简化用户操作。

用户输入的数据往往是不可靠的,所以本项目前后端都对登录信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。

注册

页面同样使用了element-ui的Dialog实现弹出蒙版对话框的效果,注册按钮设置在App.vue根组件,通过父子组件传值控制注册框是否显示。

用户输入的数据往往是不可靠的,所以本项目前后端同样都对注册信息进行了校验,前端基于element-ui的表单校验方式,自定义了校验规则进行校验。

首页

首页主要是对商品的展示,有轮播图展示推荐的商品,分类别对热门商品进行展示。

全部商品

全部商品页面集成了全部商品展示、商品分类查询,以及根据关键字搜索商品结果展示。

商品详情页

商品详情页主要是对某个商品的详细信息进行展示,用户可以在这里把喜欢的商品加入购物车或收藏列表。

我的购物车

购物车采用vuex实现,页面效果参考了小米商城的购物车。

详细实现过程请看:基于Vuex实现小米商城购物车

订单结算

用户在购物车选择了准备购买的商品后,点击“去结算”按钮,会来到该页面。 用户在这里选择收货地址,确认订单的相关信息,然后确认购买。

我的收藏

用户在商品的详情页,可以通过点击加入 喜欢 按钮,把喜欢的商品加入到收藏列表。

我的订单

对用户的所有订单进行展示。

运行项目

注意:

  • 后端接口地址已经修改为线上的地址,本地运行会直接分为我部署在服务器的后端。
  • 为了方便测试,数据库数据没有加密,注册时切记不要使用自己的常用密码
  • 如果需要自己运行后端,请移步到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

页面截图

首页

全部商品

购物车

我的收藏

我的订单

登录

注册

作者 hai-27

2020年3月8日

vue-store's People

Contributors

hai-27 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

vue-store's Issues

登录判断进购物车的问题

大哥 我都登录了 加不了购物车 你登录判断存的什么玩意 登录了加入购物车 还在那提示用户未登录让我登录 请求头里面加什么值啊??????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????

请教作者

下载文件后运行store-server后http://localhost:3000/提示的是not found 检查路由后发现没有什么问题 请问一下是什么问题呢 可能问题有点低级 但是自己排查了很久了 因为是初学者 还请作者可以帮我解答一下
微信图片_20240324070727

大佬,请教一下你。

大佬你数据库中的数据都是从哪里弄得吖?我没有数据和图片资源什么的。可以发一下给我吗?可以的话我的qq是2414821184

你好!这个项目的部署到nginx发现了动静分离的问题,想请教一下,谢谢!

是这样的,这个项目我在本地通过nodejs运行是没问题的(前端是你这个项目,后端上另一个老哥改造的springboot).

但是一部署到服务器的nginx(虚拟机)就是出问题了,图片全部报404:
于是我突然想到了,这个肯定存在动静分离的问题,静态资源和接口访问应该分开的。

但是我看到你的那个vue.config.js是这样写的。
pathRewrite: {
'^/api': '',
}

相当于把api实际置空了,但是如果这样做是有问题的,因为对应nginx来说,它必须要清楚的知道:哪些是静态资源,哪些需要去调api接口。 所以/api的路径实际上是需要的,而且非常奇怪的是我发现你把那些手机图片,全部都请求到后端的public 目录,而不是在vue本地目录请求,这实在让我有点糊涂了。

说了那么多,主要是因为我对vue不太熟,想请问一下你在生产环境nginx怎么配的,上面的这些问题是怎么解决的,谢谢!

请教问题

大佬想问一下前端项目运行后为什么无法显示呀

问题

为什么我下载你的项目,一进去就是error

1

为啥我改了api地址还是直接访问博主的接口啊

请教问题

你好,大佬,我能方便加一下您的联系方式吗?有一些技术问题想问一下,或者是加我的qq :1272792163,谢谢大佬

有个bug,一个商品达到限购数量后其他商品都无法加入购物车了

原因是详情页这个加入购物车按钮的disable是由data中dis变量控制的,而datail组件作为缓存路由组件dis变量会沿用之前的,所以一旦一个商品达到限购后dis就永久变成true了,然后导致其他所有商品详情页的加入购物车按钮都失效了,解决方法就是在activated生命周期中重置一下this.dis = false就好了

后端地址更改后,无法访问

你好,作者大大,我发现你更改了后端地址,但是vue.config.js的线上后端地址没有同步更新,所以出现无法访问的情况

问题

请教一下问题大佬,加一下QQ 1439534414

购物车功能无法正常调用问题及解决办法

购物车功能调用失败,原因是GetOrderGroup的SQL语句书写错误。
原句:select order_id from orders where user_id = ? group by order_id
修改:select order_id from (select order_id from orders where user_id = ? group by order_id ) a order by order_id desc
报错原因是SQL语句在group by分组后不能使用desc进行排序。

嗨,好兄弟

可不可以把product,product_picture这两个表以及内容导出一下啊,万分感谢

LICENCE

请问是开源项目吗,是否可以提供一个LICENCE文件。
如果是MIT协议更好,我参考使用你的前端项目。

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.