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

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

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

技术选型

1,前端

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

2,管理后台

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

3,数据后台

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

效果预览

0,新加功能

0-1,折线图,柱状图,趋势图

后续我还会不定期的增加新的功能到我们的项目里面来。。。
在这里插入图片描述

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,新加饭店地址,导航功能

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


    可导航到饭店

1-17,新加购物车页面

购物车有内容时如下

购物车为空时如下

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里设置如下权限

  "requiredPrivateInfos": ["chooseAddress","getLocation"],

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

十一,授权登录与退出

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

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,用css画个箭头

好多同学都会认为,我们下面这个箭头是个图片,其实不是,这个箭头是纯css代码画出来的。

代码如下:

.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);
}

你如果不想用这个css画的箭头,自己去网上找个箭头图片,放到这里也可以,记得图片是用image组件来显示的就可以了。

我会在视频里把css画的箭头和图片箭头都给大家演示一遍。大家自己决定用css箭头还是图片箭头。

12-2,条目布局的实现


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

可以看到核心代码如下

.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);
}

12-3,在线客服和意见反馈

我们其实在首页开发的时候已经讲过页面的跳转是用wx.navigateTo方法实现的,所以这里页面跳转不做讲解了,这里重点说的是下面两个条目的点击跳转。

在这里插入图片描述
这里的反馈建议和在线客服都是用的小程序官方自带的页面。也就是我们点击“反馈建议”和“在线客服”跳转到的是小程序官方的页面,不需要我们开发。如下。

12-3-1,在线客服

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

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

网页端客服

小程序端客服

12-3-2,意见反馈

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

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

所以我们这里需要做的就是使用官方自带的功能。而这两个功能都是通过button按钮来实现的。

我们这里用到了button的open-type属性。可以看下我们代码里用的就是这个属性。

好多同学问石头哥,在线客服和意见反馈是怎么实现的。其实就是上面几行代码就可以轻松的实现了,因为主要功能小程序官方已经帮我们实现了,我们只需要通过button打开对应的open-type就行了。

12-3-3,消除button的默认样式

因为button自带一些样式,我们的在线客服和意见反馈又必须通过button打开,所以我们要想办法消除button的默认样式。
重点代码如下:

我会在视频里给大家演示不消除css默认样式带来的影响,如下图所示,不去除button默认样式,会很难看。

十三,搜索页面的开发

还记得我们前面讲首页开发的时候有顺便讲了点搜索功能

但是第七章,只是简单的讲了下逻辑的实现。就是可以请求到数据,但是数据没有用页面显示出来。

所以今天就来手把手的教大家把搜索到的数据显示到页面上。
显示效果如下。

13-1,搜索页面效果图


可以看出我们的菜品搜索页,有顶部搜索框,和底部的菜品搜索结果列表。

13-2,搜索页顶部搜索框


可以看出我们搜索页顶部的搜索框和首页的搜索框基本上一模一样,所以我们布局上只需要把首页的搜索框复制过来就行了,正规的做法应该是抽取为一个自定义组件。但是我们本节的重点不是自定义组件,所以我们这里就在搜索页重新写下搜索框就行了。


和首页搜索框唯一不同的就是我们在首页输入的搜索词要自动填充到搜索框里,其实就是设置下input的value属性。

这里就不再带着大家一点点的敲代码了,这部分可以去看下前面首页的讲解内容。

13-3,搜索结果页的编写


细心的同学可以看出我们搜索结果列表和我们首页的热门推荐列表长得基本上差不多,唯一不同的就是我们搜索页可以做菜品的添加和减少。
所以我们这里的布局也可以直接复用首页热门推荐的。

唯一需要我们单独写的就是这个加减菜品的按钮了。

其实这里的按钮就是两个图片和一个数字。这里我会在视频里手把手的教大家把这里写出来。

<!-- 菜品列表 -->
<view wx:for="{{foodList}}" class="item" bindtap="click2"><image class="item_img" src="{{item.icon}}"></image><view><view class="item_title">{{item.name}}</view><view class="item_sell">销量:{{item.sell}}</view><view class="bottom_root"><view class="item_price">{{item.price}}</view><image bindtap="jian" data-id="{{item._id}}" class="jiajian" src="../../image/jian.png"></image><text class="num">{{item.num?item.num:0}}</text><image bindtap="jia" data-id="{{item._id}}" class="jiajian" src="../../image/jia.png"></image></view></view>
</view>

13-4,加减菜品的逻辑实现

其实这里做菜品的加减就是实现对应的点击事件,然后在点击事件里实现对应菜品数量的加减就可以了。这里我也会在视频里手把手的教大家。

十四,弹窗和总价

由于这一章的购物车涉及的逻辑比较多,所以大家笔记就作为参考就行,重点还是要跟着这节的视频课一步步的跟着石头哥去敲代码。

14-1,我们先来实现底部总价计算汇总功能

如下图所示

我会在视频里教大家具体的代码实现。

14-2,购物总价和数量的逻辑


如上图所示,总计4件总价39,就是通过在js里的逻辑代码实现的。

当然了这只是其中一部分代码,完整的代码和逻辑我会在视频里一步步带着大家去实现。

14-3,购物车数据的存放

我们需要在js页面里定义一个数组来存放购物车数据。在我们每次添加或者减少菜品的时候,这些数据都会同步的更新到我们的购物车数组里面。

有一个比较重要的知识点,这里给大家补充下,如下所示

14-3-1,检查数组里的对象是否包含某个字段

find() 方法返回数组中满足提供的测试函数的第一个元素的值。否则返回 undefined。

var objArr = [{id:1, name:'jiankian'}, {id:23, name:'anan'},{id:188, name:'superme'}, {id:233, name:'jobs'}, {id:288, name:'bill', age:89}, {id:333}
]
var ret2 = objArr.find((v) => {return v.id == 233;
});
console.log(ret2);
// return {id:233, name:'jobs'}
// 当返回undefined时,则说明objArr中没有,可以添加

14-3-2,查询数组里某个对象所在的下标

findIndex()方法返回数组中满足提供的测试函数的第一个元素的索引。否则返回-1。

var objArr = [{id:1, name:'jiankian'}, {id:23, name:'anan'}, {id:188, name:'superme'}, {id:233, name:'jobs'}, {id:288, name:'bill', age:89}, {id:333}] ;
var ret2 = objArr.findIndex((v) => {return v.id == 233;
});
console.log(ret2);
// return 3
// 当返回-1时,则说明objArr中没有,可以添加了

14-3-3,删除数组中指定的元素

array.splice(index,num)
index代表我们从何处开始删除,就是元素的下标从0开始,num代表我们删除几个元素。

    let arr = [0, 1, 2, 3, 4, 5]arr.splice(0, 2)console.log(arr)//[2, 3, 4, 5]

如上面的例子,我们从下标0开始删除两个元素。这样就是把元素0和1删除了。

14-4,购物车蒙层的实现


如上图所示,我们的购物车弹起的时候会有一个蒙层,一个购物列表,我这里先带大家实现蒙层效果,如下所示。

wxml里需要一个蒙层,一个购物列表

wxss里主要靠下面代码实现蒙层效果

这是实现蒙层的关键,里面的一些属性如果没有了解过可以自行百度学习下。当然这也是一部分代码,由于购物车里涉及的逻辑比较多,我会尽量在视频里带着大家一步步来。

14-5,购物列表的实现


如上图所示,我们购物车列表的实现和我们菜品列表基本上差不多,也用到了加减数量,但是要记住这里的加或者减少菜品和我们的菜品列表是要同步的,所以我们在点击加或者减的时候,要处理的逻辑就特别多了,我也会在视频里带着大家一步步去实现的。
其实购物车列表里的加或者减的点击和我们上面菜品列表里的加或者减的点击是一样的。

14-5-1,滑动冲突

由于我们的菜品列表和购物车列表出现在同一个页面,会有滑动事件冲突的问题,所以在购物车列表的根布局的样式里要添加 overflow: auto 属性

14-6,缓存购物车数据

由于我们的购物车数据是要全局使用的,包括我们后面的确认订单页里也是需要购物车数据的,所以我们这里把购物车数据缓存在本地,而缓存的方法我们前面讲的缓存登陆状态是一样的。

缓存很简单,就是在用户点击加或者减的时候,把整合好的数据缓存在本地。如上图所示一行代码就可以实现了,重点还是要在缓存前先整合好购物车数据。购物车数据的整合我会在视频里带着大家一步步的来实现。

14-7,清空购物车里的某条菜品

我们购物车菜品列表的最右边会有一个叉号,这个叉号就是快速的清空当前菜品。其实和我们点击减号,当数量为0时实现的效果是一样的,都是把当前菜品从购物车数组里剔除。

我会在讲解视频里带着大家一步步的实现。

十五,购物车和缓存

由于购物车是一个比较重要的功能,我们再用一章专门讲购物车和缓存功能。

15-1,效果图

首先我们来看下我们的购物车页面长什么样

如果有认真跟着石头哥前面视频学习的同学肯定会发现我们之前底部只有首页和我的,现在多了一个购物车。其实就是我们之前学习的tabar里多配置了一个页面。我会在视频里教大家配置,顺便复习下之前的知识点。

15-2,本章知识点

其实我们这一章上上面的第十四章的知识点基本上都是一样的无非就是我们上一章讲的是在弹窗里显示购物车内容,这一章讲的是在一个单独的页面里显示购物车内容。

我们在这一章里会把我们之前的知识点做一个汇总复习,这也是单独拿出来一章给大家讲解的原因。

我们将复习以下的知识点

  • 列表的显示
  • 图片的显示
  • flex弹性布局
  • 页面的跳转
  • 页面的生命周期
  • 购物车加减菜品
  • 清空购物车
  • 总价的计算
  • 缓存的复习

15-3,代码部分

我们为了加快进度,有些之前讲过的知识点就不在手把手的带着大家去敲了,要不然我们这门课会拉的很长。所以一些之前讲过的知识点,我们直接把之前的代码复制下,教大家如何修改。这也是现实工作中常用的,一些之前写过的代码和逻辑没有必要再重新写一遍了。这样为了节省开发时间,提高效率。
我会在视频里仔细的教大家去实现这个购物车页面

15-4,配套资源

我们添加购物车需要用到的图标我也给大家放到了网盘里。


当然了,你也可以自己去找图片资源。我这里只是为大家提供一个便利。

十六,确认订单页

16-1,效果图

我们这一节带大家学习确认订单页的编写,效果如下

我们接下来就会在视频里教大家从上到下的编写这个页面。

16-2,本章知识点

  • 列表显示
  • 计算求和
  • 缓存读取
  • 输入框和选择框的学习
  • 下单功能
  • 模拟支付
  • 订单状态
  • 扫码获取桌号

我会在视频里手把手的教大家,所以这一章最好认真跟着石头哥的视频走。看视频时尽量不要跳跃

16-3,扫码获取桌号

我们这里需要用到小程序的扫码识别功能,来获取桌号。
这里用到的官方提供的wx.scanCode方法

对应的官方文档如下
https://developers.weixin.qq.com/miniprogram/dev/api/device/scan/wx.scanCode.html

代码如下:

wx.scanCode({success (res) {console.log(res)}
})

十七,我的订单页

我们上一章讲了订单的提交,我们提交订单以后要有一个可以查看订单的地方吧,所以我们这一节来教大家开发我的订单页。
入口在个人中心,如下图。

17-1,效果图


通过上面的效果图我们可以看到,我们这里可以把用户的订单信息都显示出来。

17-2,本章知识点

  • 顶部自定义导航栏
  • 订单列表
  • 列表里嵌套列表
  • 取消订单
  • 评价订单
  • 各个状态下的订单列表

我会在视频教程里手把手的教大家实现这个页面。

17-3,获取当前时间

我们订单里要显示用户的下单时间,所以我们在创建订单时就需要把下单时间上传上去,所以我们要用到一个获取当前时间的方法,如下

  // 获取当前时间_getCurrentTime() {let d = new Date();let month = d.getMonth() + 1;let date = d.getDate();let hours = d.getHours();let minutes = d.getMinutes();let curDateTime = d.getFullYear() + '年';if (month > 9)curDateTime += month + '月';elsecurDateTime += month + '月';if (date > 9)curDateTime = curDateTime + date + "日";elsecurDateTime = curDateTime + date + "日";if (hours > 9)curDateTime = curDateTime + hours + "时";elsecurDateTime = curDateTime + hours + "时";if (minutes > 9)curDateTime = curDateTime + minutes + "分";elsecurDateTime = curDateTime + minutes + "分";return curDateTime;},

17-4,调起带输入框的弹窗

学过石头哥基础课的同学都知道,我们弹窗用的是wx.showModal
对应的官方文档:
https://developers.weixin.qq.com/miniprogram/dev/api/ui/interaction/wx.showModal.html

其实弹窗里是支持输入框的,只不过我们要尽量的升级到最新的基础库。


我会在视频里教大家怎么升级基础库和编写评价功能的。

十八,评价列表页

18-1,效果图

18-2,本章知识点

  • 顶部自定义导航栏
  • 全部评价列表
  • 我的评价列表
  • 云函数和小程序调用数据库的区别
  • 数据表的权限

十九,管理员登陆和管理订单

19-1,登陆页面效果图

我们先来讲登陆功能,其实在我前面的云开发基础课程里已经给大家讲过登陆了,今天就来带大家重新敲一遍代码,回顾下登陆功能。

我们在登陆成功以后就可以看到订单管理和排号管理的入口

我们这一章先讲订单管理,后面讲到排号功能的时候,再一起讲排号管理。

19-2,登陆页面知识点

  • 获取用户输入的账号密码
  • 管理员数据库的管理
  • 登陆成功和未登陆页面的切换
  • 记录登陆状态
  • 数据表的权限
  • 新加退出登陆的功能

19-3,管理用户订单效果图

其实管理员管理订单的页面和我们的用户订单页是很像的,所以可以直接参考前面的章节,当然了我也会在视频里带着大家写一遍代码的

19-4,本章知识点

  • 顶部自定义导航栏
  • 订单列表
  • 列表里嵌套列表
  • 取消订单
  • 评价订单
  • 各个状态下的订单列表

我会在视频教程里手把手的教大家实现这个页面。

二十,排号等位功能

20-1,用户端

用户端排号,可以选择就餐人数,选大桌小桌

排号成功后可以查看排号情况

20-2,管理员端

管理员可以管理当前排号情况

我会在代码里带着大家一步步去实现排号功能

二十一,菜品分类功能

21-1,为什么做菜品分类

先来回忆下菜品分类页的效果图。其实当我们菜品增多时,通过搜索是可以快速定位到某一个菜品,但是呢,如果通过菜品分类,让用户去选择购买,肯定会更方便客户的。

22-2,菜品分类的实现原理

其实呢, 我们的菜品分类就是左侧的菜品类型列表,和右侧的每个菜品分类下的菜品列表。

我会在视频里带着大家一步步的实现菜品分类功能的,希望大家认真的跟着石头哥的视频教程走。

22-3,菜品分组查询

我们想知道菜品都有哪些分类,我们就要通过聚合分组操作,拿到目前所有菜品的分组。就是要知道我们的菜品有哪些分类。

这里我们用到了云开发官方的一个聚合操作。

对应的文档如下:
https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-sdk-api/database/aggregate/Aggregate.group.html
建议大家自己去仔细读下,当然我也会在视频里教大家一步步的去实现这个功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/307942.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【STL】list

目录 1. list的使用 1.1 list的构造 1.2 list iterator的使用 1.3 list capacity 1.4 list element access 1.5 list modifiers 1.6 list的迭代器失效 2. list的模拟实现 3. list与vector的对比 1. list的使用 1.1 list的构造 1.2 list iterator的使用 1. begin与end为…

MySQL前缀索引(3/16)

前缀索引 前缀索引&#xff1a;MySQL支持前缀索引&#xff0c;允许定义字符串的一部分作为索引。如果不指定前缀长度&#xff0c;索引将包含整个字符串。前缀索引可以节省空间&#xff0c;但可能会增加查询时的记录扫描次数&#xff08;因为会查询到多个前缀相同的数据&#x…

4.9QT

完善对话框&#xff0c;点击登录对话框&#xff0c;如果账号和密码匹配&#xff0c;则弹出信息对话框&#xff0c;给出提示”登录成功“&#xff0c;提供一个Ok按钮&#xff0c;用户点击Ok后&#xff0c;关闭登录界面&#xff0c;跳转到其他界面 如果账号和密码不匹配&#xf…

Redis数据持久化 AOF RDB

Redis数据持久化 AOF RDB 1、单点 redis 的问题2、主从复制2.1 命令传播 3、Redis的持久化3.1 AOF写回策略重写机制后台重写 3.2 RDB&#xff08;默认方式&#xff09;RDB 方式&#xff1a;执行快照时&#xff0c;数据能被修改吗&#xff1f;RDB 方式总结 3.3 RDB 和 AOF 组合&…

【springboot开发】MVC和SSM

前言&#xff1a;关于MVC和SSM基本内容的梳理&#xff0c;以及两者之间的关系。 文章目录 1. 三层架构2. MVC3. SSM 1. 三层架构 三层架构是指&#xff1a; 视图层view&#xff08;表现层&#xff09;: 用于显示数据和接收用户输入的数据&#xff0c;为用户提供一种交互式操作…

684. 冗余连接

684. 冗余连接 原题链接&#xff1a;完成情况&#xff1a;解题思路&#xff1a;参考代码&#xff1a;错误经验吸取 原题链接&#xff1a; 684. 冗余连接 https://leetcode.cn/problems/redundant-connection/description/ 完成情况&#xff1a; 解题思路&#xff1a; 这段…

[react优化] 避免组件或数据多次渲染/计算

代码如下 点击视图x➕1,导致视图更新, 视图更细导致a也重新大量计算!!这很浪费时间 function App() {const [x, setX] useState(3)const y x 2console.log(重新渲染, x, y);console.time(timer)let a 0for (let index 0; index < 1000000000; index) {a}console.timeE…

论文阅读AI工具链

文献检索 可以利用智谱清言来生成合适的文献检索式&#xff0c;并根据需要不断调整。 谷歌学术 在Google Scholar中进行检索时&#xff0c;您可以使用类似的逻辑来构建您的搜索式&#xff0c;但是语法会有所不同。Google Scholar的搜索框接受普通的文本搜索&#xff0c;但是…

面试-数据库基础以及MySql、ClickHost、Redis简介

面试-数据库基础以及MySql、ClickHost、Redis简介 0.数据完整性1.数据库并发控制1.1事物1.2 并发读写错误1.3 锁1.3.1 乐观锁与悲观锁1.3.2 共享锁和排他锁1.3.3 行锁与表锁1.3.4 意向锁 1.4 封锁协议与隔离级别1.5 MVCC1.5.1 概念1.5.2 当前读与快照读1.5.3 MVCC in InnoDB 2.…

基于 RisingWave 和 ScyllaDB 构建事件驱动应用

概览 在构建事件驱动应用时&#xff0c;人们面临着两大挑战&#xff1a;1&#xff09;低延迟处理大量数据&#xff1b;2&#xff09;实现流数据的实时摄取和转换。 结合 RisingWave 的流处理功能和 ScyllaDB 的高性能 NoSQL 数据库&#xff0c;可为构建事件驱动应用和数据管道…

数字乡村探索:引领农村未来发展新方向——科技创新赋能乡村现代化与农民生活品质提升之旅

目录 一、数字乡村的内涵与特点 二、数字乡村的探索进展 三、数字乡村面临的挑战与机遇 四、数字乡村的未来发展方向与路径 五、数字乡村助力农村产业升级 六、数字乡村促进城乡融合发展 七、数字乡村激发农民创新创业活力 八、数字乡村提升农民获得感和幸福感 九、展…

操作系统(第四周 第二堂)

目录 回顾 进程运行 进程的创建 进程的工作 举例 进程的删除 举例1&#xff08;走到return 0结束&#xff09; 举例2&#xff08;利用exit&#xff08;1&#xff09;结束&#xff09; 进程通信 共享内存 生产者算法 消费者算法 消息传递 定义 算法实现 总结 回顾…

Redis:发布和订阅

文章目录 一、介绍二、发布订阅命令 一、介绍 Redis的发布和订阅功能是一种消息通信模式&#xff0c;发送者&#xff08;pub&#xff09;发送消息&#xff0c;订阅者&#xff08;sub&#xff09;接收消息。这种功能使得消息发送者和接收者不需要直接建立连接&#xff0c;而是通…

《前端防坑》- JS基础 - 你觉得typeof nullValue === null 么?

问题 JS原始类型有6种Undefined, Null, Number, String, Boolean, Symbol共6种。 在对原始类型使用typeof进行判断时, typeof stringValue string typeof numberValue number 如果一个变量(nullValue)的值为null&#xff0c;那么typeof nullValue "?" const u …

商标没有去注册有哪些不好的影响!

有些商家咨询普推知产老杨&#xff0c;商标没有去注册有哪些不好的影响&#xff0c;其实对企业来说还有许多实际不利的影响&#xff0c;有时代价比注册一个商标要大很多。 想的商标名称没去注册商标&#xff0c;如果别人抢注拿下商标注册证&#xff0c;那就会涉及侵权&#xf…

树上启发式合并(dsu on tree)学习

声明&#xff1a;本文部分内容摘自OI Wiki网站。详情可自行查看学习。 洛谷 P9233 题目实际上是蓝桥杯 2023 年 A 组省赛的一道题。题干大致的意思是&#xff0c;给定一个含有 n n n 个结点&#xff0c;并且以 1 1 1 为根的一棵树&#xff0c;每个节点 i i i 都有一个颜色 …

springcloud第4季 springcloud-alibaba之nacos篇

一 nacos 1.1 nacos作用介绍 nacos是一个分布式的配置中心和注册发现中心。 nacos是 dynamic naming configuration service nacosconfigbus 实现动态刷新&#xff1b;nacosconsul 1.2 各个注册中心对比 注册中心CAP模型控制台管理社区活跃度EureakaAp支持低zkcp不支持中…

将Visio绘图导出PDF文件,使其自适应大小,并去掉导入Latex的边框显示

问题描述 将Visio绘图导成pdf文件&#xff0c;首先在Visio绘图如下&#xff1a; 如果直接导出或者另存为pdf文件&#xff0c;则会发现pdf文件是整个页面大小&#xff0c;而不是图片大小。而且在导入latex等排版工具现实时&#xff0c;会显示边框。 问题解决 1.调整Visio中的页…

【攻防世界】题目名称-文件包含

看到 include()&#xff0c;想到文件包含&#xff0c;用php伪协议。 知识点 看到 include()&#xff0c;require()&#xff0c;include_once()&#xff0c;require_once() &#xff0c;想到文件包含&#xff0c;用php伪协议 ?filenamephp://filter/readconvert.base64-encode/…

zabbix监控配置(添加主机、主机组和添加监控项等)

zabbix监控配置 文章目录 zabbix监控配置1.添加主机组2.添加主机&#xff08;linux&#xff09;3.添加主机&#xff08;windows&#xff09;4.监控项配置&#xff08;通过模板添加&#xff09;5.监控项配置&#xff08;手动添加&#xff09; 1.添加主机组 2.添加主机&#xff0…