• Stars
    star
    518
  • Rank 85,414 (Top 2 %)
  • Language
    JavaScript
  • Created about 6 years ago
  • Updated almost 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

基于mpvue 框架. Vue.js开发、搭建一套完整的美团外卖点餐小程序项目,以及小程序项目架构设计实践

mpvue-meituan

mpvue-meituan 是一款使用mpvue开发的实战小程序项目,完全仿制美团官方外卖点餐小程序开发而成,项目的框架结构完全按照企业开发架构搭建而成。结合了原生小程序的开发能力和Vue能力,使小程序开发起来更加便捷高效,项目使用了比较流行的Vuex框架来作为全局的状态数据管理,使数据交互更加的便捷,结合了sass的使用让写Css样式更加的得心应手。目前市面上有很多使用mpvue开发的示例Demo,但是那些示例Demo都过于简单,没有提供一套系统的框架结构,借鉴的意义不是很大。所以作者就开源了一个企业级框架开发的小程序供大家学习参考,总之是一个极力推荐学习的小程序实战项目。

掘金专栏文章详解:mpvue-meituan

目录

项目简介

mpvue-meituan 是一款使用mpvue开发的小程序,完全仿制美团官方外卖小程序。目前市面上大部分的小程序开发还是使用微信原生的开发能力,原生的开发能力约束太多,导致小程序开发成本变高。于是市面上衍生出不少小程序开发框架,其中最为流行的有下面三个框架:wepy taro mpvue。这三个框架出自不同的大厂,之前不太了解的小伙伴们可以自行查阅资料。本项目主要介绍如何使用vue来快速开发一款复杂的小程序项目。

主要功能(20+页面)

  • 首页Tab
    • 首页商家列表
    • 选择收货地址列表
    • 选择城市
    • 商品搜索列表
    • 分类列表
    • 邀请好友领红包
    • 添加购物车页面
    • 食品档案
  • 订单Tab
    • 订单列表
    • 提交订单
    • 商品备注
    • 订单详情
    • 商品评论
  • 我的Tab
    • 我的页面
    • 美团红包页面
    • 无效红包页面
    • 代金券页面
    • 无效代金券列表
    • 收货地址列表
    • 新增收货地址
    • 帮助反馈
    • 协议说明
  • 待补充

预览效果图

安装调试

# install dependencies
npm install

# serve with hot reload at localhost:8080
npm run dev

# build for production with minification
npm run build

# build for production and view the bundle analyzer report
npm run build --report

API数据来源

mpvue-meituan 项目的数据来源目前均来自美团外卖小程序抓包数据,将抓包数据存储为本地JSON,然后工程访问本地JSON数据。由于美团外卖小程序属于美团正式线上产品,故不能直接访问其真实API,使用本地JSON一样能实现绝大部分需求,少数需要数据交互的需求自己mock数据即可。

技术要点

  • 微信原生小程序开发能力
  • mpvue开发小程序能力
  • Vue开发能力
  • less,sass 等css编译器用法
  • 小程序开发基础框架结构搭建
  • 小程序网络层封装
  • Vuex全局状态管理框架的使用
  • 小程序,vue组件化开发技巧
  • 小程序中iconFont使用技巧
  • 使用canvas绘制小程序分享海报技巧
  • 待补充

核心组件库

  • mpvue
  • vuex
  • lodash
  • mpvue-wxparse
  • minapp-api-promise
  • 待补充

开发中遇到的坑

待补充

待完成功能

  • 选择城市列表
  • 分类筛选功能
  • 购物车页面完善优化
  • 发表评论功能
  • 提交订单页面完善优化
  • canvas绘制分享海报
  • 网络层工具封装
  • vuex状态管理使用
  • 常用工具类封装
  • 组件化使用
  • sass环境的搭建及使用
  • 待补充

目录结构

.
├── App.vue
├── action
│   └── action.js
├── app.json
├── assets
│   ├── global.scss
│   └── iconfont.less
├── components
│   ├── card.vue
│   └── sep-line.vue
├── constants
│   ├── commonType.js
│   ├── errorCodeMap.js
│   ├── hostConfig.js
│   ├── pathConfig.js
│   └── responseCode.js
├── main.js
├── middlewares
│   └── index.js
├── network
│   ├── cache
│   │   └── cache.js
│   └── request
│       ├── HttpExtension.js
│       └── HttpRequest.js
├── pages
│   ├── addAddress
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── addressList
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── categoryList
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── citySearch
│   │   ├── index.vue
│   │   └── main.js
│   ├── citys
│   │   ├── index.vue
│   │   └── main.js
│   ├── commentList
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── couponList
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── dicedActivity
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── expiredCoupon
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── expiredRedPacket
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── feedback
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── home
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── index
│   │   ├── index.vue
│   │   └── main.js
│   ├── me
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── orderDetail
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── orderList
│   │   ├── data.js
│   │   ├── index.vue
│   │   └── main.js
│   ├── pickProtocol
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── protocol
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── redPacket
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── remark
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── searchList
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── selectAddress
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── share
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   ├── shoppingCart
│   │   ├── data.js
│   │   ├── index.vue
│   │   ├── main.js
│   │   └── main.json
│   └── submitOrder
│       ├── data.js
│       ├── index.vue
│       ├── main.js
│       └── main.json
├── store
│   ├── index.js
│   ├── modules
│   │   ├── shoppingCart.js
│   │   └── submitOrder.js
│   └── mutations-type.js
└── utils
    ├── arrayExtension.js
    ├── bus.js
    ├── deepClone.js
    ├── deviceInfo.js
    ├── formatTime.js
    ├── index.js
    ├── mta_analysis.js
    ├── regex.js
    ├── stringExtension.js
    ├── style.js
    ├── toast.js
    └── wxapi.js

37 directories, 117 files

总结

mpvue-meituan 项目是作者大约使用了2周时间开源的一款小程序项目,项目中基本涵盖了企业开发中常用的技术要点,非常适合想学习小程序开发的小伙伴们参考学习。相信此项目能给小伙伴们带来不一样的收获。大家也可以加作者的mpvue小程序交流群交流学习(QQ群号:694979037)。

当然,如果老铁们认为作者的开源项目还不错,也请点个 star 支持一下 ❤️❤️❤️❤️ ,也衷心的欢迎小伙伴们提些宝贵的意见和建议。

掘金专栏文章详解:mpvue-meituan

欢迎小伙伴们扫码进群

mpvue

更多文章

  • 作者React Native开源项目OneM地址(按照企业开发标准搭建框架完成开发的):https://github.com/guangqiang-liu/OneM:欢迎小伙伴们 star
  • 作者简书主页:包含60多篇RN开发相关的技术文章http://www.jianshu.com/u/023338566ca5 欢迎小伙伴们:多多关注多多点赞
  • 作者React Native QQ技术交流群:620792950 欢迎小伙伴进群交流学习

License

MIT

More Repositories

1

OneM

OneM是一款纯ReactNative打造的集杂志浏览、音乐播放、视频播放于一体的综合性App, 项目完全使用Redux状态管理,完全按照企业级架构标准搭建项目架构,项目中支持自定义多种UI组件和工具组件,支持iOS和Android双平台 ,墙裂推荐小伙伴们参考学习。
JavaScript
1,362
star
2

iOS-Component-Pro

iOS 组件化开发项目架构设计,结合 MVVM 设计模式 + RAC 数据绑定 + Pod 组件管理, 实现一套实战性的iOS组件化架构
Objective-C
669
star
3

react-navigation-demo

对导航组件react-navigation的使用讲解
JavaScript
78
star
4

iOS-MVVM-RAC

iOS MVVM开发模式 配合 RAC 信号绑定框架让开发更高效有趣
Objective-C
67
star
5

react-native-video-demo

reactNative中封装的仿爱奇艺视频播放器demo
JavaScript
57
star
6

react-native-toastAndLoading

封装一个基于iOS与Android双平台的Toast组件和加载Loading组件
JavaScript
46
star
7

react-native-gradientNavigationBarDemo

实现类似天猫首页的滑动导航颜色渐变效果组件
Objective-C
42
star
8

react-native-fetch-demo

自定义reactNative中的fetch网络请求工具类
JavaScript
38
star
9

react-native-shoppingCartDemo

封装仿京东APP购物车组件
JavaScript
34
star
10

CodePushDemo

RN项目接入CodePush实现热更新技术
Objective-C
32
star
11

react-native-categoryListDemo

仿天猫商品类目分类列表页面
JavaScript
28
star
12

AutoPackageScript

iOS、Android自动打包脚本文件
Shell
27
star
13

iOS-NotificationExtensionDemo

iOS 10 处理杀进程语音播放,串行语音播报问题,通知扩展类详解
Objective-C
27
star
14

OneM-API

总结出OneM开源项目中使用到的模块数据API
26
star
15

react-native-audio-demo

reactNative中封装的仿网易音乐播放器功能demo
JavaScript
24
star
16

react-native-routerFluxDemo

react-native-router-flux路由组件使用方式Demo
JavaScript
19
star
17

OneM-preview

纯ReactNative项目OneM中的页面效果图预览表
17
star
18

iOSHybridRNDemo

iOS原生与RN混合开发,入门Demo示例
Objective-C
17
star
19

redux-saga-todoListDemo

redux-saga框架版本的 todoListDemo, 适合初学者更好的理解 redux-saga 框架的使用
JavaScript
16
star
20

react-native-shareLogin

集成QQ微信分享登录功能Demo
Objective-C
15
star
21

react-dva-counter

入门dva框架的Counter Demo, 用来帮助同学们理解dva 框架的思想
JavaScript
15
star
22

iOS-Hybrid-RNDemo

iOS原生嵌套React Native实战开发,高级用法
JavaScript
14
star
23

iOS-Specs

iOS 组件化开发私有specs索引库
Ruby
13
star
24

react-native-storage-Demo

在react-native-storage组件的基础上封装storage 数据存储组件单利工具类
JavaScript
13
star
25

react-dva-todoList

dva版本的todoList项目,用来帮初学者更好的理解dva框架
JavaScript
12
star
26

redux-saga-counterApp

使用redux-saga框架搭建的 CounterApp Demo,帮助初学者更好的理解 redux-saga 框架
JavaScript
11
star
27

react-native-keyboardManager

解决在iOS平台下的,键盘遮挡文本框问题
Objective-C
7
star
28

react-native-gaussianBlurDemo

实现页面背景图片高斯模糊效果
Objective-C
7
star
29

react-native-ant-design-demo

reactNative中接入蚂蚁金服Ant-Design组件库
Objective-C
6
star
30

react-native-navigator-component-demo

reactNative中封装一套自定义的导航栏组件
JavaScript
5
star
31

react-native-ArrayTool

封装一个实用的数组操作工具类
JavaScript
5
star
32

react-native-commonStyleSheet

封装一个基于UI标准的公用样式表
JavaScript
5
star
33

react-native-iconfont

reactNative工程中使用iconFont,以及自定义font库
Objective-C
5
star
34

react-native-reduxDemo

学习理解redux框架之CounterDemo和TodoDemo
JavaScript
4
star
35

iOS-ModuleB-Category

iOS 组件化开发中,业务模块B的路由导航组件
Objective-C
3
star
36

iOS-Widget

iOS widget 基础组件
Objective-C
3
star
37

iOS-BaseView

iOS 基类 view 组件库
Objective-C
3
star
38

MarkdownSyntax

史上最全Markdown常用语法总结,学习Markdown看我就够了
3
star
39

iOS-Component-Middleware

iOS 组件化开发中各个独立模块组件间的调度中心管理器
Objective-C
3
star
40

react-native-styleSheet-demo

reactNative中封装的一套适配iOS和Android双平台的基类样式表组件
Objective-C
2
star
41

iOS-Modal

iOS modal 弹框 组件库
Objective-C
2
star
42

11.3-AutoreleasePool

11.3-autoreleasePool底层原理ARC,讲解示例Demo
Objective-C
2
star
43

iOS-PickerView

iOS picker 组件
Objective-C
2
star
44

iOS-IconFont

iOS iconFont 组件
Objective-C
2
star
45

06-BlockDemo

06-iOS中block底层原理,本质讲解示例Demo
C++
2
star
46

06.6-BlockDemo6

06.6-block循环引用,讲解示例Demo
C++
2
star
47

iOS-Module-Category

iOS 组件化开发中电子发票业务模块组件分类,用于进行调度器路由导航跳转
Objective-C
2
star
48

iOS-Form

iOS form 表单组件库
Objective-C
2
star
49

11.1-AutoreleasePool

11.1-autoreleasePool底层原理(iOS),讲解示例Demo
C++
2
star
50

iOS-moduleB

iOS 组件化开发实践中的业务模块B 组件
Objective-C
2
star
51

RAC-API-Demo

2
star
52

GQSafeKit

一个使用runtime实现的简单的工程safe框架
Objective-C
2
star
53

07.2-RunTimeSuper

07.2-Runtime super关键字,讲解示例Demo
C++
1
star
54

06.2-BlockDemo2

06.2-iOS中block的类型,讲解示例Demo
Objective-C
1
star
55

11-AutoreleasePool

11-ARC局部对象释放时机,讲解示例Demo
Objective-C
1
star
56

06.4-BlockDemo

06.4-block捕获对象类型的变量,讲解示例Demo
C++
1
star
57

08-Runloop

08-Runloop的本质,讲解示例Demo
Objective-C
1
star
58

08.2-RunloopThread

08.2-Runloop控制线程的生命周期,讲解示例Demo
Objective-C
1
star
59

07-RumtimeMethodCache

07-Runtime方法缓存,讲解示例Demo
Objective-C
1
star
60

09-GCD

09-多线程之GCD,讲解示例Demo
Objective-C
1
star
61

08.1-Runloop

08.1-Runloop的实际应用场景,讲解示例Demo
Objective-C
1
star
62

react-native-validator-demo

reactNative中封装的一套表单提交参数自动校验组件
1
star
63

10-NSTimer

10-内存管理中NSTimer常见问题,讲解示例Demo
Objective-C
1
star
64

03-KVO

03-iOS中KVO底层实现原理Demo讲解
Objective-C
1
star
65

04-KVC

04-iOS KVC底层本质,实现原理Demo讲解
Objective-C
1
star
66

07.3-RunTime-isMemberOfClass-isKindOfClass

07.3-RunTime中 isMemberOfClass,isKindOfClass的本质区别,讲解示例Demo
Objective-C
1
star
67

05-Category

05-iOS中Category底层原理,Demo讲解
C++
1
star
68

MarkDownImgs

Markdown 上需要访问的图片仓库
1
star
69

06.3-BlockDemo3

06.3-iOS中block的copy,讲解示例Demo
Objective-C
1
star
70

06.5-__blockDemo

06.5-block中__block本质,讲解示例Demo
C++
1
star
71

07.1-RunTimeMessageSend

07.1-Runtime消息机制,讲解示例Demo
C++
1
star
72

09.1-ThreadLock

09.1-多线程中的各种锁,讲解示例Demo
Objective-C
1
star
73

RN-Demo

本项目是作者公司的CRM试验性RN项目,由于CRM选择使用原生开发,顾此项目就没有发布上线,作者就将其开源出来供大家学习参考
1
star
74

10.1-__weak

10.1 __weak底层原理,讲解示例Demo
Objective-C
1
star
75

11.2-AutoreleasePool

11.2-autoreleasePool底层原理,讲解示例Demo
Objective-C
1
star
76

06.1-BlockDemo1

06.1-iOS中block的变量捕获,讲解示例Demo
C++
1
star