手把手带你开发一款云开发版点餐小程序,微信扫码点餐,店铺地图导航,外卖小程序,用户端和后厨端都有

从今天开始带领大家实现一款云开发版的点餐小程序

视频讲解:《云开发后台+微信扫码点餐小程序+cms网页管理后台》

技术选型

1,前端

  • 微信小程序原生框架
  • css
  • JavaScript

2,管理后台

  • 云开发Cms内容管理系统
  • web网页

3,数据后台

  • 小程序云开发
  • 云函数
  • 云数据库
  • 云存储

效果预览

1,小程序端

1-1,首页

首页有以下几个功能点

  • 1,点餐
  • 2,菜单浏览
  • 3,排号等位
  • 4,饭店地址
  • 5,顶部轮播图
  • 6,搜索菜品
  • 7,热门菜品推荐

这里点餐分两种

  • 1,可以设置直接点餐
    直接点餐:适合小型饭店,或者奶茶类的快餐店。直接就可以下单,不用识别桌号

  • 2,也可设置扫码点餐
    扫码点餐适合中大型饭店,可以区分桌号,方便管理

    我后面会教大家如何生成桌号二维码,只需要把对应桌号的二维码贴在餐桌上,用户点击 扫码点餐 识别二维码,即可获取到桌号信息。

1-2,菜品浏览页

菜品浏览分两种

  • 1,不带分类
    适合菜品少的时候
  • 2,带分类
    菜品多的时候,带分类更方便客户选择

不带分类

带分类

1-3,搜索功能

我们这里搜索有两个触发方式

  • 1,直接点击搜索图标
  • 2,点击键盘上的搜索键

1-4,搜索结果,支持模糊查询

如我这里只搜‘鱼’,那么菜品中所有包含鱼的都可以搜索到

1-5,购物车

首先菜品列表页可以直接添加商品到购物车

购物车弹起后可以做如下操作

  • 1,增删单个菜品
  • 2,清空购物车
  • 3,删除菜品

这些操作都和菜品列表是联动的,也就是菜品列表和购物车里增删个数,都是可以同步的。我会在项目预览章节的视频里做具体演示。

1-6,下单页

下单页就是确认订单后进行下单支付的。有以下功能

  • 1,点餐明细
  • 2,价格计算
  • 3,桌号地址
  • 4,就餐人数
  • 5,添加备注
  • 6,点击下单

1-7,支付页

支付页分两种方式

  • 1,模拟支付
    适合前期学习,毕业设计等演示类的场景。
  • 2,真实微信支付
    适合商用,但是使用微信支付必须要有营业执照,所以前期如果只是学习的话,建议使用模拟支付。

所以我们的源码提供两个版本

模拟支付

真实微信支付

1-8,我的订单页

我的订单页分以下几个状态

  • 1,新下单待上餐
  • 2,已上餐待评价
  • 3,订单完成
  • 4,订单取消

1-9,提交评论页

我们可以对店家进行评论。

1-10,评价列表页

可以查看所有评价和自己的评价

1-11,排号等位


可以看出,我们可以选择就餐人数,排大桌或者小桌。我这里已排小桌为例

通过上图可以看出

  • 1,当前排号情况
  • 2,我的排号
  • 3,可以重新排号
  • 4,到号时会有到号提示

后面我会把订阅消息功能加进来,这样到号后会有订阅消息提示。

1-12,个人中心

个人中心分登录和未登录两种状态

未登录

已登录

1-13,微信授权登录小程序

1-14,在线客服

客户直接在小程序里发消息给客服

客服可以在网页端,或者微信端管理消息

网页端客服

小程序端客服

1-15,意见反馈

客户可以直接在小程序端提建议,建议里可以添加图片

管理员可以在小程序后台,查看客户的反馈

1-16,新加饭店地址,导航功能

  • 地图上显示饭店地址
  • 饭店手机
  • 饭店微信
  • 导航到饭店


    可导航到饭店

2,后厨端和排号管理端

2-1,后厨端主要供后厨的厨师使用

  • 1,可以查看当前新下单
  • 2,完成后可以操作菜品完成
  • 3,可以监听用户新下单
  • 4,有新订单时会有语音提示
  • 5,厨师登录页

语音提示我会在视频课里具体演示

厨师登录页

厨师管理页

可以查看待制作订单

用户新下单后,会有语音提示

2-2,排号管理页

同样也有登录页,和上面厨师登录一样,这里重点看下排号管理页

管理员可以查看当前排号情况,可以叫号。

3,cms管理后台

我们这里的可视化网页后台使用的时云开发自带的cms(内容管理)

3-1,登录页

3-2,管理后台


我们可以在这里

  • 1,添加轮播图,删除轮播图,修改轮播图
  • 2,添加菜品,删除菜品,修改菜品,上架下架菜品
  • 3,管理订单
  • 4,查看评价
  • 5,管理后厨和排号管理员
  • 6,查看排号数据


比如我查询某个用户的所有订单

查询所有新下单还未上菜的订单

还有更多的功能,我会在视频课里给大家用视频来演示,这样更直观。

4,数据库

数据库我们这里用云开发自带的云数据库

配套资料

1,讲解视频

视频课我会在B站免费提供给大家,欢迎关注,欢迎三连。
https://space.bilibili.com/419474640/video

2,配套笔记

配套笔记会在csdn上免费给到大家,欢迎关注,笔记会持续更新。
https://blog.csdn.net/qiushi_1990

3,支持石头哥😊

3-1,源码和配套资源获取

目前源码和配套的一些资源暂时不免费,如果有需要的同学可以私聊石头哥,拿米来换。

3-2,笔记电子书

笔记我也有整理一套电子书,大家也可以私聊石头哥获取电子书版的配套笔记。电子书笔记方便后期查询知识点。

3-3,配置商业版点餐小程序

可以联系石头哥配置商业版的点餐小程序。

4,问题解答(●’◡’●)

另外石头哥提供配套解答服务。当然了,知识付费时代石头哥解答是要米的,毕竟石头哥精力有限,石头哥也是要吃面包的。石头哥有推出包月,包年解答服务。你在学习过程中有任何问题,或者工作中遇到任何编程问题,都可以来找石头哥
石头哥目前可以解答如下问题

  • 小程序方面的问题
  • 云开发方面的问题
  • Java,springboot,Javaweb方面的问题
  • 毕设方面的问题
  • 安卓app开发方面的问题
  • html+css+JavaScript方面的问题
  • 前端开发的问题
  • 后端开发的问题
  • 面试找工作方面的问题

源码版本

我目前提供下面两个版本的源码,不同的源码适合不同的场景。后面也都会做具体讲解,所以后面源码导入部分一定要认真看,我模拟支付和真实支付都会做讲解。

1,模拟支付版

  • 这个版本适合毕业设计,初级学习等演示性的场合
  • 不需要营业执照

2,真实微信支付版

  • 这个版本适合饭店,餐厅等商业场景使用
  • 必须有营业执照才可以

一,源码导入和云开发的初始化

我源码会在配套资料里给到付费用户,年卡用户也可以获取到

1-1,源码的下载

前期学习,只下载模拟支付版的源码

1-2,源码的导入

导入源码的时候一定要把appid换成你自己的。appid需要注册小程序才有的,所以学习这门课之前建议你先去看下我云开发基础课:《零基础人入门小程序云开发》

appid获取的位置如下图。

1-3,云开发的初始化

初始化云开发之前,必须先开通云开发。

1-3-1,初始化云开发环境id

点击云开发,进入云开发控制台。如果没有这个图标,说明你上面导入源码时用的不是自己的appid。所以一定要用自己的appid

获取环境id

把环境id复制到app.js里,把下面部分替换成你自己的环境id

1-3-2,云函数选择环境

这里要注意,选择的环境,必须和你app.js里填入的环境id保持一致。

1-4,云函数的部署

cloud目录下的云函数都要部署一下

1-5,下单提示音频的上传


复制上传好的音频链接,到app.js里替换一下

二,开通Cms可视化网页管理后台

我们上面源码导入成功,并把云开发环境初始化成功以后,接下来就来开通cms可视化网页后台

2-1,进入云开发控制台开通内容管理(CMS)

如下图所示,直接点击开通内容管理(CMS)即可

点击完开通以后,会有如下弹窗,直接点击确定即可。不要被付费吓着,官方每月会送我们一定的免费额度的。学习得话基本上够用了。

上面点完确定后,我们只是开启了按量付费功能,因为cms得使用必须要开通按量付费才可以得。所以还要再点一次开通。如下图

点完开通后,会有如下弹窗,直接点击下一步即可。

然后我们需要设置登录内容管理后台得账号和密码,然后点击确定即可

然后我们就等待内容管理功能得开通了,需要等几分钟。

开通成功以后,我们就可以通过下面这个地址进入管理后台了。

2-2,登录Cms可视化管理后台

上面开通好以后,就可以通过后台地址登录管理后台了。如下

2-3,创建项目

第一次登录,我们还需要创建一个项目

自己输入项目名和项目id即可

然后点击进入刚刚创建的项目

到这里我们的cmd可视化网页管理后台就创建好了,下面教大家如何导入数据。

三,导入数据并修改数据库权限

3-1,在cms后台导入内容模型


把我为大家提前准备好的内容模型.json文件导入即可

导入完以后,可以看到多了以下几个表

3-2,导入菜品和轮播图数据


数据我已经为大家准备好了,大家只需要按照我视频里的步骤把这两个数据导入到对应的表里即可。

菜品导入成功如下

轮播图导入成功如下

3-3,修改轮播图和菜品表的权限

把lunbotu这个表的权限改为所有用户可读,仅创建者可读写。

把food这个表的权限改为 所有用户可读,仅创建者可读写。

3-4,修改订单表和admin表的权限

把order这个表的权限改为所有用户可读,仅创建者可读写。

把admin这个表的权限改为所有用户可读,仅创建者可读写。

四,源码的大致讲解(选看)

首先来给大家说下pages里的每个页面

新加了饭店地址页面


cloud云函数如下

我会在视频里把每个页面的代码快速大致的给大家讲解下。这节可以作为选看,后面会手把手的教大家写一款属于自己的点餐小程序。

五,创建新项目

今天我们就来正式的开始手把手的开发了。后面的每一节都很重要,希望大家好好听。

首先是创建新项目,这里一定要记得用自己的appid,所以你要提前去注册一个属于自己的小程序,小程序的注册我小程序基础课里有讲过。
《10小时零基础入门小程序开发》

5-1,appid获取的位置如下图

5-2,创建项目

注意事项: 一定要用自己的appid

六,首页轮播图的开发

6-1,要实现的效果图


本节知识点

  1. swiper组件
  2. swiper-item组件
  3. image组件
  4. wx:for列表循环
  5. 云数据库请求数据
  6. cms后台操作
  7. 轮播图的增删改查

这些知识点在基础课里都有讲解,所以这里不会讲太细,会带大家快速的过一遍。

6-2,对应文档

  • swiper组件文档
    https://developers.weixin.qq.com/miniprogram/dev/component/swiper.html
  • swiper-item组件
    https://developers.weixin.qq.com/miniprogram/dev/component/swiper-item.html
  • image组件
    https://developers.weixin.qq.com/miniprogram/dev/component/image.html

七,搜索功能的开发

7-1,搜索框的页面布局


我会在视频里教大家实现一个和上图一样的页面。

7-2,本节知识点

  1. input组件
  2. 点击事件
  3. 模糊搜索
  4. 获取用户输入内容

我会在视频里给大家做详细讲解。

7-3,对应文档

这里只需要看一个重点知识点的文档即可,其余的知识点我在基础课里都有做讲解。

  • 模糊搜索关键知识点文档:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-sdk-api/database/Database.RegExp.html

我们这一节的难点就在这个模糊搜索上,所以接下来会重点给大家讲解这个模糊搜索。这也是我们实现搜索功能的关键所在。

  • 核心代码如下:
	db.collection('food').where({
      name: db.RegExp({
        regexp: searchKey,
        options: 'i'
      })
    }).get()

八,九宫格分类布局的开发

就是下面红色框里的这个区域

接下来就教大家如何开发这个区域。

8-1,去源码里拿到图片资源

首先去源码的image目录下,把我们需要的几个图片资源复制进来。

就是下面这几个,如果你前面跟着石头哥视频课操作的话,所有的图片资源应该都已经放好了。

8-2,wxml和wxss的编写

这里先把整体代码截图给到大家,如下图所示。

左侧是wxml,右侧是wxss样式。这里每个分类都有自己的bindtap点击事件,点击后会跳转到不同的页面。

8-3,在js里编写点击事件

这里定义的点击事件,就是点击后做页面跳转,用到了 wx.navigateTo这个知识点。

对应的官方文档如下。

其实小程序里页面跳转有下面4种方式的。

我们这里最常用的就是 wx.navigateTo 。其实这些知识点,我在小程序基础入门课里有讲的:https://edu.csdn.net/course/detail/9531

到这里我们的九宫格分类区域就编写好了。

九,热门菜品推荐

效果图如下

9-1,wxml页面布局

wxml页面代码如下,我会在视频课程里具体讲解

9-2,wxss样式

wxss页面代码如下

这里把几个重点知识给大家补充讲解下。

9-2-1,标题超过指定宽度省略号

效果图和核心代码如下

9-2-2,在文字前面添加人民币符号

9-2-3,查看更多居于右侧


这里主要用了flex布局的justify-content属性,用来定义了项目在主轴上的对齐方式

这里建议大家去百度下 flex 花5分钟学习下,绝对保证你收益终身。

9-3,数据的获取

我们这里可以有两种方式请求到数据
1,直接通过云开发数据库获取数据
2,也可以通过云函数获取数据

由于直接通云开发数据库获取数据,我基础课里讲了太多遍,这里我们就通过云函数来获取。云函数代码如下。

注意:云函数里面初始化云开发环境用下面的代码

cloud.init({
  env: cloud.DYNAMIC_CURRENT_ENV
})

调用云函数的代码如下

9-4,查看更多的点击事件


如上图所示,点击查看更多时,依然是跳转到菜品列表页。

十,饭店信息(地图标记,导航,联系方式)

10-1,老规矩,先看效果图

10-1-1,可以在地图上显示店铺位置,地址,联系方式

10-1-2,点击位置可以调起导航功能

10-2,获取经纬度

因为小程序内置的是腾讯地图,所以你需要到腾讯地图上查询经纬度。
首先,你要明确一个事情,任何位置都有它的 经纬度 ,所以你首先要获取到你想定位位置的经纬度。

腾讯地图经纬度查询:https://lbs.qq.com/tool/getpoint/index.html

如我这里的经纬度:30.353351,120.231010
要记住纬度在前,经度在后。所以我这里的纬度是30.353351,经度是120.231010

10-3,设置wxml页面

我先把代码截个图出来。

然后把代码贴出来给到大家

<map style="width:100%; height:700rpx;" longitude="{{longitude}}" latitude="{{latitude}}" scale="17"
  markers="{{markers}}"  bindmarkertap="navRoad" data-marker="{{markers[0]}}"
  show-location />
<view class="phone" bindtap="Call">
  地址:杭州市丁兰广场C座
</view>
<view class="phone" bindtap="Call">
  电话:2501902696(可点击拨打)
</view>

这里我们用到了小程序的map组件来显示地图,可以直接设置经纬度和标记点。

10-4,编写js代码

我先把代码截图贴出来给到大家

然后把代码给到大家

Page({
  data: {
    //店铺经纬度
    latitude: 30.353351,
    longitude: 120.231010,
    //标记点
    markers: [{
      id: 0,
      name: "编程小石头",
      address: "杭州市丁兰广场C座",
      latitude: 30.353351,
      longitude: 120.231010,
      width: 50,
      height: 50
    }]

  },
  //拨打电话
  Call() {
    wx.makePhoneCall({
      phoneNumber: '2501902696'
    })
  },
  //导航
  navRoad(event) {
    console.log(event)
    wx.getLocation({ //获取当前经纬度
      type: 'wgs84', //返回可以用于wx.openLocation的经纬度,
      success: function (res) {
        wx.openLocation({ //​使用微信内置地图查看位置。
          latitude: event.currentTarget.dataset.marker.latitude, //要去的纬度-地址
          longitude: event.currentTarget.dataset.marker.longitude, //要去的经度-地址
          name: event.currentTarget.dataset.marker.name,
          address: event.currentTarget.dataset.marker.address
        })
      }
    })
  }
})

这里其实就点击导航事件比较麻烦些,其他的都还好。注释里给大家标的很清楚了。

10-5,设置定位权限

到这里其实代码已经完成了,但是我们导航的时候需要用到用户的位置权限,所以我们要在app.json里设置用户授权

如果不设置,点击导航会有如下提示。

所以我们要在app.json里设置

  "permission": {
    "scope.userLocation": {
      "desc": "导航需要" 
    }
  },

到这里我们就可以很方便的让用户找到我们了。

十一,授权登录与退出

我们的项目开发多多少少的都会用到用户的一些信息,比如头像,昵称,性别等。而这些信息的获取,小程序也为我们提供好了方法。

11-1,认识wx.getUserProfile方法


对应的文档:https://developers.weixin.qq.com/miniprogram/dev/api/open-api/user-info/wx.getUserProfile.html

使用这个方法可以获取如下的用户信息

11-2,授权弹窗

一般我的使用上面的wx.getUserProfile方法获取用户信息时,需要用户授权的。一般授权弹窗如下。

只有用户点击允许以后才可以获取用户信息。

不弹起授权弹窗解决方案

有的同学用这个方法时,不会弹起上面的弹窗,有可能是因为基础库版本太低,这里建议升级到最新版的基础库。

11-3,授权登录核心代码

等下视频课程里会带着大家一起敲代码,这里先把一些核心代码贴出来。其实核心代码官方文档里有提供的。

这里为了方便日后大家使用,我贴出来给到大家。这里要注意 desc必须保留,里面的描述尽量写的规范些。因为

    wx.getUserProfile({
      desc: '用于完善会员资料', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
      success: (res) => {
      }
    })

11-4,顶部圆形头像和昵称


其实这里倒是挺简单,重点知识只有一个圆形图片的实现这里只需要一个image组件和一个text组件即可。通过css的border-radius就可以来设置圆形图像了,我小程序基础里也有讲过的,核心代码如下。

11-5,本地缓存的讲解

11-5-1,使用wx.setStorageSync缓存

这里缓存我们主要用到了wx.setStorageSync 对应的官方文档:
https://developers.weixin.qq.com/miniprogram/dev/api/storage/wx.setStorageSync.html

11-5-2,缓存数据的查看

如下图所示,就是我们的本地缓存数据

11-5-3,使用wx.getStorageSync获取缓存


对应的官方文档:https://developers.weixin.qq.com/miniprogram/dev/api/storage/wx.getStorageSync.html

11-6,退出登录的编写

退出登录其实很简单,就实现一个点击事件就可以了

然后js里具体代码就下面这几行就够了

11-7,完整的项目代码

我这里把wxml和js的完整代码贴出来给到大家
index.wxml

<button wx:if="{{!userInfo}}" bindtap="login">授权登录</button>
<view wx:else class="root">
  <image class="touxiang" src="{{userInfo.avatarUrl}}"></image>
  <text class="nicheng">{{userInfo.nickName}}</text>
  <button bindtap="loginOut">退出登录</button>
</view>

index.js

Page({
  data: {
    userInfo: ''
  },
  onLoad() {
    let user = wx.getStorageSync('user')
    console.log('进入小程序的index页面获取缓存', user)
    this.setData({
      userInfo: user
    })
  },
  // 授权登录
  login() {
    wx.getUserProfile({
      desc: '必须授权才可以继续使用',
      success: res => {
        let user = res.userInfo
        // 把用户信息缓存到本地
        wx.setStorageSync('user', user)
        console.log("用户信息", user)
        this.setData({
          userInfo: user
        })
      },
      fail: res => {
        console.log('授权失败', res)
      }
    })
  },
  // 退出登录
  loginOut() {
    this.setData({
      userInfo: ''
    })
    wx.setStorageSync('user', null)
  }
})

index.wxss

.root {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.touxiang {
  width: 200rpx;
  height: 200rpx;
  border-radius: 50%;
  margin-top: 30rpx;
  margin-bottom: 10rpx;
}

我会在视频里带大家做具体代码的编写。
《小程序入门》

十二,个人中心的编写

今天我们就来讲解下个人中心的编写。

12-1,条目布局的实现


我们这里以我的订单条目为例

可以看到核心代码如下

.my_item {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 17px;
  background: white;
  border-bottom: 1px solid gainsboro;
}

.right_arrow {
  border: solid black;
  border-width: 0 3px 3px 0;
  padding: 3px;
  position: absolute;
  right: 15px;
  /* margin-left: 66%; */
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}
编程小石头 Python PHP MySQL
码农一枚,非著名全栈开发人员。分享自己的一些经验,学习心得,希望后来人少走弯路,少填坑。编程小石头和你一起快乐的学编程。
相关推荐