当前位置:   article > 正文

基于JAVA,SpringBoot,Vue,UniAPP外卖订餐点餐小程序设计

基于JAVA,SpringBoot,Vue,UniAPP外卖订餐点餐小程序设计

摘要

随着移动互联网技术的飞速发展和智能手机的普及,外卖订餐小程序已经成为餐饮服务行业的重要组成部分。基于SpringBoot框架和UniAPP平台开发的外卖订餐小程序系统设计,旨在提供一个轻量级、高效且用户友好的在线订餐解决方案。SpringBoot作为一个开源的Java-based微服务框架,为后端服务提供了快速开发的能力,简化了企业级应用的构建过程。而UniAPP则是一个使用Vue.js开发跨平台应用的前端框架,它允许开发者通过编写一次代码,发布到iOS、Android、Web以及各种小程序等多个平台。

本系统设计注重于架构的高可用性、扩展性和安全性,以支持不断变化的市场需求和保障用户数据安全。在技术栈的选择上,结合SpringBoot的强大生态和UniAPP的跨平台优势,可以加速开发流程,降低维护成本,并提高最终产品的市场适应性。整个系统的设计考虑了模块化和服务化的原则,便于未来功能的迭代与拓展,同时确保用户体验的连贯性和系统的响应速度。通过这种设计,外卖订餐小程序能够在竞争激烈的市场中保持竞争力,满足消费者对便捷餐饮服务的需求。

整个项目实现的功能

三种角色,分别是管理员、商家、买家,均是小程序。使用微信授权登录。

普通用户: 1.浏览商品信息、查看分类 2.浏览推荐商品信息(根据销量推荐) 3.添加购物车和结算订单 4.查看个人订单详情,对订单进行评价 5.申请成为商家 6.修改收货地址等功能;

商家: 1.管理所有商品信息,可以上传商品 2.管理所有订单信息,进行发货等;

管理员: 管理商品分类、审核商品等。

使用的技术

使用的框架:后端SpringBoot框架,java语言。前端UniApp框架,Vue.js语法。

使用的数据库:MySql5.7或8

部分代码展示

  1. <template>
  2. <view class="content">
  3. <view class="navbar">
  4. <view
  5. v-for="(item, index) in navList" :key="index"
  6. class="nav-item"
  7. :class="{current: tabCurrentIndex === index}"
  8. @click="tabClick(index)"
  9. >
  10. {{item.text}}
  11. </view>
  12. </view>
  13. <swiper :current="tabCurrentIndex" class="swiper-box" duration="300" @change="changeTab">
  14. <swiper-item class="tab-content" v-for="(tabItem,tabIndex) in navList" :key="tabIndex">
  15. <scroll-view
  16. class="list-scroll-content"
  17. scroll-y
  18. @scrolltolower="loadData"
  19. >
  20. <!-- 空白页 -->
  21. <empty v-if=" tabItem.orderList.length === 0"></empty>
  22. <!-- 订单列表 -->
  23. <view
  24. v-for="(item,index) in tabItem.orderList" :key="index"
  25. class="order-item"
  26. >
  27. <view class="i-top b-b">
  28. <text class="time">{{item.createTime}}</text>
  29. <text class="state" :style="{color: item.stateTipColor}">{{getStat(item.stat)}}</text>
  30. <text
  31. v-if="item.state===9"
  32. class="del-btn yticon icon-iconfontshanchu1"
  33. @click="deleteOrder(index)"
  34. ></text>
  35. </view>
  36. <scroll-view v-if="item.goods.length > 1" class="goods-box" scroll-x>
  37. <view
  38. v-for="(goodsItem, goodsIndex) in item.goods" :key="goodsIndex"
  39. class="goods-item"
  40. >
  41. <image class="goods-img" :src="picUrl + goodsItem.pic1" mode="aspectFill"></image>
  42. </view>
  43. </scroll-view>
  44. <view
  45. v-if="item.goods.length === 1"
  46. class="goods-box-single"
  47. v-for="(goodsItem, goodsIndex) in item.goods" :key="goodsIndex"
  48. >
  49. <image class="goods-img" :src="picUrl + goodsItem.pic1" mode="aspectFill"></image>
  50. <view class="right">
  51. <text class="title clamp">{{goodsItem.title}}</text>
  52. <text class="attr-box">{{goodsItem.name}} x {{goodsItem.num}}</text>
  53. <text class="price">{{goodsItem.price}}</text>
  54. </view>
  55. </view>
  56. <view class="price-box">
  57. <text class="num">{{item.goods.length}}</text>
  58. 件商品 实付款
  59. <text class="price">{{item.priceAll}}</text>
  60. </view>
  61. <view class="action-box b-t" v-if="item.stat == 3">
  62. <!-- <button class="action-btn" @click="cancelOrder(item)">取消订单</button> -->
  63. <button class="action-btn recom" @click="getComment(item)">立即评价</button>
  64. </view>
  65. <view class="action-box b-t" v-if="item.stat == 2&&user.uid == item.userFk">
  66. <button class="action-btn recom" @click="changeOrder(item.id,3)">收货</button>
  67. </view>
  68. <view class="action-box b-t" v-if="item.stat == 1&&user.type == 2">
  69. <button class="action-btn recom" @click="changeOrder(item.id,2)">发货</button>
  70. </view>
  71. <view class="action-box b-t" v-if="item.stat == 4">
  72. <text class="u-tips-color">已完成</text>
  73. </view>
  74. </view>
  75. <uni-load-more :status="tabItem.loadingType"></uni-load-more>
  76. </scroll-view>
  77. </swiper-item>
  78. </swiper>
  79. <u-modal v-model="show" title="评论" @confirm="commentSub">
  80. <view class="slot-content">
  81. <view class="u-flex u-p-20 u-border-bottom" v-if="selItem.length > 0" v-for="(item ,index) in selItem">
  82. <image style="width: 100rpx;height:100rpx;" :src="picUrl+item.pic1"></image>
  83. <u-input class="u-m-20 u-m-l-30" type="text" placeholder="请输入评论" v-model="item.memo" placeholderStyle="textAlign:center"/>
  84. </view>
  85. </view>
  86. </u-modal>
  87. </view>
  88. </template>

演示视频

基于JAVA,Vue,UniAPP外卖订餐点餐小程序系统设计

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/131122
推荐阅读
相关标签
  

闽ICP备14008679号