酒吧酒馆微信小程序设计基于Java,SpringBoot,Vue和UniApp

摘要

该设计目标是创建一个集成了Java, SpringBoot, Vue和UniApp技术的酒吧微信小程序,为用户提供一个功能全面、操作便捷的服务体验。通过利用SpringBoot的高效微服务架构,后端能够快速处理用户请求,实现酒品浏览、订单管理等核心功能,并保证系统的稳定性和可伸缩性。前端采用Vue.js框架构建用户界面,以实现响应式设计和动态交互,提供美观、流畅的用户体验。借助UniApp,将进一步将Web应用无缝转换为微信小程序,让用户在微信环境中也能轻松访问酒吧服务,包括查看商品、加购下单等。总体来说,这个基于Java, SpringBoot, Vue和UniApp的酒吧微信小程序设计致力于提升传统酒吧的客户服务质量,为现代消费者提供一个集便捷预订、信息查询和社交互动于一体的数字平台。

实现的功能

角色分为管理员、员工、普通用户三种。

管理员(PC端Web页面):登录、个人信息管理、用户管理、商品分类管理、商品信息管理、库存管理、订单管理等;

员工(PC端Web页面):登录、创建订单、查询订单、商品查询、库存管理等;

普通用户(小程序端):登录、首页(商品推荐、特色商品)、商品页面(商品信息显示、加入购物车)、购物车、提交订单(确认信息、备注、下单)、订单详情(支付情况、订单信息等)、我的(个人信息、订单查询、查看购物车)。

用到的技术

后端:Java语言的SpringBoot框架、MySql数据库、Maven依赖管理等;

前端:Vue.js语法的UniApp框架,可编译成微信小程序。

部分代码展示

<template>
	<view class="content">
		<scroll-view scroll-y class="left-aside">
			<view v-for="(item,index) in typeList" :key="item.id" class="f-item b-b" :class="{active: selIndex == index}" @click="tabtap(item,index)">
				{{item.groupName}}
			</view>
		</scroll-view>
		<scroll-view scroll-with-animation scroll-y class="right-aside" @scroll="asideScroll" :scroll-top="tabScrollTop">
			<view>
				<text class="s-item">{{typeList[selIndex].groupName}}</text>
				<view class="t-list">
					<view @click="navToDetailPage(item)" class="t-item" v-for="item in goodsList" :key="item.id">
						<image :src="filePath + item.pic"></image>
						<text>{{item.title}}</text>
					</view>
				</view>
			</view>
		</scroll-view>
	</view>
</template>

<script>
	import appRequest from "../../common/appRequestUrl.js";
	export default {
		data() {
			return {
				sizeCalcState: false,
				tabScrollTop: 0,
				currentId: 0,
				flist: [],
				slist: [],
				tlist: [],
				goodsList:[],
				typeList:[],
				filePath:appRequest.urlMap.getFile,
				selType:{},
				selIndex:0
			}
		},
		onLoad(){
			//this.loadData();
			this.getTypeList();
		},
		methods: {
			navToDetailPage(item) {
				//测试数据没有写id,用title代替
				let id = item.id;
				uni.navigateTo({
					url: `/pages/product/product?id=${id}`
				})
			},
			getGoods(type){
				let _this = this;
				appRequest.request({
				  data: {
				    validFlag: 1,
					state:1,
					type:type
				  },
				  url: appRequest.urlMap.findNmGoodsList,
				  success: function(res) {
				    if (res.data.code == 200) {
				      _this.goodsList = res.data.data;
				    } else {
				      appRequest.msg(res.data.msg);
				    }
				  },
				  fail: function(res) {
				   appRequest.msg("网络异常");
				  }
				});
			},
			getTypeList(){
				let _this = this;
				appRequest.request({
				  data: {
				    validFlag: 1
				  },
				  url: appRequest.urlMap.findNmGoodsTypeList,
				  success: function(res) {
				    if (res.data.code == 200) {
				      _this.typeList = res.data.data;
					  _this.getGoods( _this.typeList[0].id)
				    } else {
				      appRequest.err(res.data.msg);
				    }
				  },
				  fail: function(res) {
				    appRequest.err("网络异常");
				  }
				})
			},
			async loadData(){
				let list = await this.$api.json('cateList');
				list.forEach(item=>{
					if(!item.pid){
						this.flist.push(item);  //pid为父级id, 没有pid或者pid=0是一级分类
					}else if(!item.picture){
						this.slist.push(item); //没有图的是2级分类
					}else{
						this.tlist.push(item); //3级分类
					}
				}) 
			},
			//一级分类点击
			tabtap(item,selindex){
				this.getGoods(item.id)
				if(!this.sizeCalcState){
					this.calcSize();
				}
				this.selIndex = selindex;
				this.currentId = item.id;
				let index = this.slist.findIndex(sitem=>sitem.pid === item.id);
				this.tabScrollTop = this.slist[index].top;
				
			},
			//右侧栏滚动
			asideScroll(e){
				if(!this.sizeCalcState){
					this.calcSize();
				}
				let scrollTop = e.detail.scrollTop;
				let tabs = this.slist.filter(item=>item.top <= scrollTop).reverse();
				if(tabs.length > 0){
					this.currentId = tabs[0].pid;
				}
			},
			//计算右侧栏每个tab的高度等信息
			calcSize(){
				let h = 0;
				this.slist.forEach(item=>{
					let view = uni.createSelectorQuery().select("#main-" + item.id);
					view.fields({
						size: true
					}, data => {
						item.top = h;
						h += data.height;
						item.bottom = h;
					}).exec();
				})
				this.sizeCalcState = true;
			},
			navToList(sid, tid){
				uni.navigateTo({
					url: `/pages/product/list?fid=${this.currentId}&sid=${sid}&tid=${tid}`
				})
			}
		}
	}
</script>

演示视频

基于Java,Vue和UniApp酒吧酒馆小程序管理系统设计

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

大话设计模式之外观模式

外观模式&#xff08;Facade Pattern&#xff09;是一种软件设计模式&#xff0c;旨在提供一个简单的接口&#xff0c;隐藏系统复杂性&#xff0c;使得客户端能够更容易地使用系统。这种模式属于结构型模式&#xff0c;它通过为多个子系统提供一个统一的接口&#xff0c;简化了…

华为OD机试 - 最大社交距离(Java 2024 C卷 100分)

华为OD机试 2024C卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷C卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测试…

央视315推荐的护眼灯有哪些?护眼灯十大品牌推荐

台灯作为家居类不可或缺的一种照明灯具&#xff0c;在我们的日常生活中发挥着重要作用&#xff0c;尤其是对于经常需要在夜晚长时间用眼学习的孩子而言&#xff0c;能够提供充足、明亮的照明&#xff0c;对学习帮助是非常大的。然而台灯的选择也是有讲究的&#xff0c;市面上很…

MongoDB 6.1 及以上版本使用配置文件的方式启动报错 Unrecognized option: storage.journal.enabled

如果你使用的 MongoDB 的版本大于等于 6.1&#xff0c;并且在 MongoDB 的配置文件中编写了如下内容 storage:journal:# 启用或禁用持久性日志以确保数据文件保持有效和可恢复# true 启用&#xff1b;false 不启用# 64 位系统默认启用&#xff0c;启用后 MongoDB 可以在宕机后根…

黄金票据的复现

实验环境以及工具 服务器&#xff1a;Windows server 2003 用户&#xff1a;Windows 7旗舰版 工具&#xff1a;mimikatz 搭建服务器环境 参考&#xff1a;内网横向——域渗透之黄金票据复现-CSDN博客 创建用户 使用gpupdate刷新策略&#xff1b; 搭建win7环境 设置ip ‘…

SpringBoot实现邮箱验证

目录 1、开启邮箱IMAP/SMTP服务&#xff0c;获取授权码 2、相关代码 1、使用配置Redis&#xff08;用于存储验证码&#xff0c;具有时效性&#xff09; 2、邮箱依赖和hutool&#xff08;用于随机生成验证码&#xff09; 3、配置Redis和邮箱信息 4、开启Redis服务 5、编写发送…

天诚人脸物联网锁搭载智慧公寓管理系统,赋能公寓智慧租住与通行管理

随着我国各大城市大规模地更新进程&#xff0c;各地掀起了人才公寓、地产品牌公寓、长短租公寓建设的浪潮&#xff0c;城中村改造也成为各地热门的民生话题。全场景AIoT解决方案服务商——江苏新巢天诚智能技术有限公司&#xff08;以下简称“天诚”&#xff09;从社区居民“租…

耐腐蚀耐高温实验室塑料烧杯进口高纯PFA材质反应器特氟龙烧杯

PFA烧杯在实验过程中可作为储酸容器或涉及强酸强碱类实验的反应容器&#xff0c;用于盛放样品、试剂&#xff0c;可搭配电热板加热、蒸煮、赶酸用。 外壁均有凸起刻度&#xff0c;直筒设计&#xff0c;带翻边&#xff0c;便于夹持和移动&#xff0c;边沿有嘴&#xff0c;便于倾…

nvm的使用

需求&#xff1a;不同项目使用的是不同版本的node版本 思路&#xff1a;可以使用nvm来管理和实现不同版本的切换使用 1.nvm的使用环境 如果电脑之前安装有node需要卸载node&#xff0c;并把yarn的环境变量删除&#xff08;没有可以省略这一步&#xff09; 2.nvm的下载及安装…

C-偶遇行军蚁(遇到过的题,做个笔记)

我的代码: 思路就是把每一行看成一个字符串&#xff0c;然后逐渐增加字符就行 #include <iostream> #include <vector> using namespace std; int main() {string s;int n;cin >> n; //读入行数cin >> s; //读入字符串vector<string>arr(n…

LeetCode 209 长度最小的子数组(滑动窗口,双指针实现)

给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续 子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度。如果不存在符合条件的子数组&#xff0c;返回 0 。 示例 1&#xff1a; 输入&…

工具推荐:简单好用的企业知识管理SaaS产品合集

在这个信息爆炸的时代&#xff0c;企业的每位员工都在每天处理大量的信息与知识&#xff0c;如果没有合适的工具来管理这些宝贵资源&#xff0c;很容易造成知识的流失或重复劳动。幸好&#xff0c;现在有了很多知识管理SaaS&#xff08;即服务软件&#xff09;产品可以帮助我们…

深信服超融合虚拟机的导入方法

以从vmware虚拟机导出的虚拟机为例。 1 进入虚拟机页面点【新增】&#xff0c;选择【导入虚拟机】 2 以文件类型为ovf、mf、vmdk为例导入 选择文件类型&#xff0c;选择那三个导出的虚拟机的文件&#xff0c;选择分组&#xff0c;存储位置和运行位置默认&#xff0c;操作系统…

Android 自定义View 测量控件宽高、自定义viewgroup测量

1、View生命周期以及View层级 1.1、View生命周期 View的主要生命周期如下所示&#xff0c; 包括创建、测量&#xff08;onMeasure&#xff09;、布局&#xff08;onLayout&#xff09;、绘制&#xff08;onDraw&#xff09;以及销毁等流程。 自定义View主要涉及到onMeasure、…

Matlab实验:IIR数字滤波器设计

01.实验内容及原理 02.代码效果图 获取代码请关注MATLAB科研小白的个人公众号&#xff08;即文章下方二维码&#xff09;&#xff0c;并回复&#xff1a;MATLAB实验本公众号致力于解决找代码难&#xff0c;写代码怵。各位有什么急需的代码&#xff0c;欢迎后台留言~不定时更新科…

人人都离不开的算法:AI 时代的生存指南

文章目录 一、算法在生活中的“无处不在”二、算法在工作学习中的“智慧助力”三、算法在社会发展中的“驱动力量”四、算法带来的“双刃剑”效应五、应对算法挑战的策略《人人都离不开的算法——图解算法应用》编辑推荐1、通俗易懂2、技术科普3、贴近时代、贴近生活4、启发思考…

企业微信知识库的搭建方法都在这里了,赶紧收藏!

如果你是一位希望在企业内部实现高效知识共享和管理的管理者&#xff0c;搭建一个企业微信知识库可能是你最佳的选择之一。在这篇文章中&#xff0c;我将以简单明了的方式向大家介绍如何在企业微信上搭建和管理一个知识库。 首先&#xff0c;让我们了解一下什么是企业微信知识库…

学成在线_统一账号密码认证_http测试报错500

问题 在进行统一账号密码认证的http测试时报错500&#xff0c;如下图所示 问题原因 由于我们期待的账号和密码认证是通过userDetailsService对象来实现的&#xff0c;所以当我们将userDetailsService对象注入DaoAuthenticationProviderCustom类后需要屏蔽原本的密码比对。 …

深信服:借助观测云实现全链路可观测性

导读 深信服科技股份有限公司 简称「深信服」&#xff08; Sangfor Technologies Inc. &#xff09;&#xff0c;是一家领先的网络安全和云计算解决方案提供商&#xff0c;致力于为全球客户提供高效、智能、安全的网络和云服务。随着公司业务的不断扩展&#xff0c;也面临着监…

WIFI驱动移植实验:WIFI从路由器动态获取IP地址与联网

一. 简介 前面两篇文章&#xff0c;一篇文章实现了WIFI联网前要做的工作&#xff0c;另一篇文章配置了WIFI配置文件&#xff0c;进行了WIFI热点的连接。文章如下&#xff1a; WIFI驱动移植实验&#xff1a;WIFI 联网前的工作-CSDN博客 WIFI驱动移植实验&#xff1a;连接WIF…