10.二次开发——黑马程序员Java最新AI+若依框架项目

目录

  • 前言
  • 零、使用若依修改器修改项目名称
  • 一、创建sky-merchant模块
    • 1.创建模块
    • 2. 在新模块中导入依赖
    • 3. 父工程锁定版本
    • 4. sky-admin 导入依赖
  • 二、菜品管理页面生成
    • 1.根据页面原型,确定表信息
    • 2.设计表
    • 3使用代码生成器生成页面
    • 4,下载tb_dish代码并分别导入到前端、后端、数据库
    • 5.使用clean清理,重启项目
    • 6.在菜单管理中,将菜品管理升级到主类目
    • 7.刷新页面
    • 8.测试功能
    • 9.解决修改时,口味不能回显问题
  • 三、列表改造
    • 1 存在问题
    • 2 AI辅助,下载通义灵码
    • 3. AI辅助修改代码
  • 四、口味改造
    • 1.问题
    • 2,解决办法
  • 五、页面调整(修改logo、系统名称、删除不需要部分)
    • 1.浏览器标签页icon、标题
    • 2.系统页面中的logo、标题
    • 3.去除源码&文档
    • 4.主题和自定义图标
    • 5.登录页面中标题、背景图

前言

提示:本篇将完成菜品管理的前后端开发

零、使用若依修改器修改项目名称

  1. 下载链接:点我
  2. 使用
    在这里插入图片描述

一、创建sky-merchant模块

1.创建模块

在这里插入图片描述

2. 在新模块中导入依赖

在这里插入图片描述

3. 父工程锁定版本

在这里插入图片描述

4. sky-admin 导入依赖

在这里插入图片描述

二、菜品管理页面生成

1.根据页面原型,确定表信息

信息获取:先查看新增菜品,再查看展示页面信息进行补充。
在这里插入图片描述
在这里插入图片描述

2.设计表

这里我们使用黑马提供的下载资料。下载后,向数据库导入菜品管理SQL;
在这里插入图片描述

3使用代码生成器生成页面

  • 1.导入菜单和口味表

在这里插入图片描述

  • 2.根据页面原型设置信息
    新增原型:
    在这里插入图片描述
    菜单页面原型:
    在这里插入图片描述
    由上述两张表确定代码生成内容:
    基本信息:
    在这里插入图片描述
    字段信息:
    在这里插入图片描述
    因售卖状态为下拉框,所以需在字典管理中添加售卖状态字典。
    在这里插入图片描述
    生成信息:
    在这里插入图片描述

4,下载tb_dish代码并分别导入到前端、后端、数据库

之前已经讲了导入方法,这里就不赘述了。
详情请看:点我第三部分
在这里插入图片描述

5.使用clean清理,重启项目

在这里插入图片描述

6.在菜单管理中,将菜品管理升级到主类目

在这里插入图片描述

7.刷新页面

图片远程调用服务器,可能是黑马已经删了,所以不显示。
在这里插入图片描述
理由:查看数据库tb_dish表的image字段
在这里插入图片描述

8.测试功能

  • 新增菜品
    在这里插入图片描述
  • 删除菜品
    在这里插入图片描述
  • 修改菜品
    在这里插入图片描述

9.解决修改时,口味不能回显问题

解决办法
在这里插入图片描述

三、列表改造

1 存在问题

  • 主键需要删除
  • 价格前需要加上¥
  • 时间需要加上时分秒
  • 图片回显不能显示
    在这里插入图片描述
    在这里插入图片描述

2 AI辅助,下载通义灵码

IDEA
在这里插入图片描述
VsCode
在这里插入图片描述

3. AI辅助修改代码

  • 修改id回显
    在这里插入图片描述

  • 在价格前加上¥
    在这里插入图片描述

  • 将时间修改为年月日时分秒格式
    在这里插入图片描述

在这里插入图片描述

  • 解决在修改操作图片不能回显问题
    问题:
    在这里插入图片描述
    解决:
    全部AI解决,我们只需要定位到图片加载所在文件及可;
    在这里插入图片描述
    效果:
    在这里插入图片描述

四、口味改造

1.问题

口味需要客户进行书写,不够友好,我们的目标如下,使得用户直接选择就可以。
在这里插入图片描述

2,解决办法

下面就不一 一放图了,直接给源代码:

具体代码如下:

<template><div class="app-container"><el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px"><el-form-item label="菜品名称" prop="name"><el-inputv-model="queryParams.name"placeholder="请输入菜品名称"clearable@keyup.enter="handleQuery"/></el-form-item><el-form-item label="售卖状态" prop="status"><el-select v-model="queryParams.status" placeholder="请选择售卖状态" clearable><el-optionv-for="dict in dish_status":key="dict.value":label="dict.label":value="dict.value"/></el-select></el-form-item><el-form-item><el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button><el-button icon="Refresh" @click="resetQuery">重置</el-button></el-form-item></el-form><el-row :gutter="10" class="mb8"><el-col :span="1.5"><el-buttontype="primary"plainicon="Plus"@click="handleAdd"v-hasPermi="['merchant:dish:add']">新增</el-button></el-col><el-col :span="1.5"><el-buttontype="success"plainicon="Edit":disabled="single"@click="handleUpdate"v-hasPermi="['merchant:dish:edit']">修改</el-button></el-col><el-col :span="1.5"><el-buttontype="danger"plainicon="Delete":disabled="multiple"@click="handleDelete"v-hasPermi="['merchant:dish:remove']">删除</el-button></el-col><el-col :span="1.5"><el-buttontype="warning"plainicon="Download"@click="handleExport"v-hasPermi="['merchant:dish:export']">导出</el-button></el-col><right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar></el-row><el-table v-loading="loading" :data="dishList" @selection-change="handleSelectionChange"><el-table-column type="selection" width="55" align="center" /><!-- <el-table-column label="主键" align="center" prop="id" /> --><el-table-column label="菜品名称" align="center" prop="name" /><!-- <el-table-column label="售价" align="center" prop="price" /> --><el-table-column label="售价" align="center"><template #default="{ row }"><span>{{ row.price }}</span></template></el-table-column><el-table-column label="图片" align="center" prop="image" width="100"><template #default="scope"><image-preview :src="scope.row.image" :width="50" :height="50"/></template></el-table-column><el-table-column label="售卖状态" align="center" prop="status"><template #default="scope"><dict-tag :options="dish_status" :value="scope.row.status"/></template></el-table-column><el-table-column label="更新时间" align="center" prop="updateTime" width="180"><template #default="scope"><span>{{ parseTime(scope.row.updateTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span></template></el-table-column><el-table-column label="操作" align="center" class-name="small-padding fixed-width"><template #default="scope"><el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['merchant:dish:edit']">修改</el-button><el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['merchant:dish:remove']">删除</el-button></template></el-table-column></el-table><paginationv-show="total>0":total="total"v-model:page="queryParams.pageNum"v-model:limit="queryParams.pageSize"@pagination="getList"/><!-- 添加或修改菜品管理对话框 --><el-dialog :title="title" v-model="open" width="600px" append-to-body><el-form ref="dishRef" :model="form" :rules="rules" label-width="80px"><el-form-item label="菜品名称" prop="name"><el-input v-model="form.name" placeholder="请输入菜品名称" /></el-form-item><el-form-item label="售价" prop="price"><el-input v-model="form.price" placeholder="请输入售价" /></el-form-item><el-form-item label="图片" prop="image"><image-upload v-model="form.image"/></el-form-item><el-form-item label="描述信息" prop="description"><el-input v-model="form.description" placeholder="请输入描述信息" /></el-form-item><el-form-item label="售卖状态" prop="status"><el-select v-model="form.status" placeholder="请选择售卖状态"><el-optionv-for="dict in dish_status":key="dict.value":label="dict.label":value="parseInt(dict.value)"></el-option></el-select></el-form-item><el-divider content-position="center">菜品口味关系信息</el-divider><el-row :gutter="10" class="mb8"><el-col :span="1.5"><el-button type="primary" icon="Plus" @click="handleAddDishFlavor">添加</el-button></el-col><el-col :span="1.5"><el-button type="danger" icon="Delete" @click="handleDeleteDishFlavor">删除</el-button></el-col></el-row><el-table :data="dishFlavorList" :row-class-name="rowDishFlavorIndex" @selection-change="handleDishFlavorSelectionChange" ref="dishFlavor"><el-table-column type="selection" width="50" align="center" /><el-table-column label="序号" align="center" prop="index" width="50"/><el-table-column label="口味名称" prop="name" width="150"><template #default="scope"><!-- <el-input v-model="scope.row.name" placeholder="请输入口味名称" /> --><el-select v-model="scope.row.name" placeholder="请选择口味名称"@change="changeFlavorName(scope.row)" ><el-optionv-for="dishFlavor in dishFlavorListSelect":key="dishFlavor.name":label="dishFlavor.name":value="dishFlavor.name"/></el-select></template></el-table-column><el-table-column label="口味列表" prop="value" width="350"><template #default="scope"><!-- <el-input v-model="scope.row.value" placeholder="请输入口味列表" /> --><el-select v-model="scope.row.value" placeholder="请选择口味列表" multiple@focus="focusFlavorName(scope.row)" style="width: 90%;"><el-optionv-for="value in checkValueList":key="value":label="value":value="value"/></el-select></template></el-table-column></el-table></el-form><template #footer><div class="dialog-footer"><el-button type="primary" @click="submitForm">确 定</el-button><el-button @click="cancel">取 消</el-button></div></template></el-dialog></div>
</template><script setup name="Dish">
import { listDish, getDish, delDish, addDish, updateDish } from "@/api/merchant/dish";
import { ref } from "vue";const { proxy } = getCurrentInstance();
const { dish_status } = proxy.useDict('dish_status');const dishList = ref([]);
const dishFlavorList = ref([]);
const open = ref(false);
const loading = ref(true);
const showSearch = ref(true);
const ids = ref([]);
const checkedDishFlavor = ref([]);
const single = ref(true);
const multiple = ref(true);
const total = ref(0);
const title = ref("");const data = reactive({form: {},queryParams: {pageNum: 1,pageSize: 10,name: null,status: null,},rules: {name: [{ required: true, message: "菜品名称不能为空", trigger: "blur" }],price: [{ required: true, message: "售价不能为空", trigger: "blur" }],image: [{ required: true, message: "图片不能为空", trigger: "blur" }],status: [{ required: true, message: "售卖状态不能为空", trigger: "change" }],}
});const { queryParams, form, rules } = toRefs(data);
//-----------------------------
// 定义口味名称和口味列表静态数据
const dishFlavorListSelect=ref([{name:"辣度",value:["不辣","微辣","中辣","重辣"]},{name:"忌口",value:["不要葱","不要蒜","不要香菜","不要辣"]},{name:"甜味",value:["无糖","少糖","半糖","多糖"]}
]);
// 存储当前选中口味列表数组
const checkValueList=ref([]);
// 定义改变口味名称时更新当前选中的口味列表
function changeFlavorName(row){// 清空当前行valuerow.value=[];// 根据选中name去查找静态数据的valuecheckValueList.value=dishFlavorListSelect.value.find(item=>item.name==row.name).value;
}
// 定义口味列表获取焦点时更新当前选中的口味列表
function focusFlavorName(row){// 根据选中name去查找静态数据的valuecheckValueList.value=dishFlavorListSelect.value.find(item=>item.name==row.name).value;
}//-----------------------------
/** 查询菜品管理列表 */
function getList() {loading.value = true;listDish(queryParams.value).then(response => {dishList.value = response.rows;total.value = response.total;loading.value = false;});
}// 取消按钮
function cancel() {open.value = false;reset();
}// 表单重置
function reset() {form.value = {id: null,name: null,price: null,image: null,description: null,status: null,createTime: null,updateTime: null};dishFlavorList.value = [];proxy.resetForm("dishRef");
}/** 搜索按钮操作 */
function handleQuery() {queryParams.value.pageNum = 1;getList();
}/** 重置按钮操作 */
function resetQuery() {proxy.resetForm("queryRef");handleQuery();
}// 多选框选中数据
function handleSelectionChange(selection) {ids.value = selection.map(item => item.id);single.value = selection.length != 1;multiple.value = !selection.length;
}/** 新增按钮操作 */
function handleAdd() {reset();open.value = true;title.value = "添加菜品管理";
}/** 修改按钮操作 */
function handleUpdate(row) {reset();const _id = row.id || ids.valuegetDish(_id).then(response => {form.value = response.data;dishFlavorList.value = response.data.dishFlavorList;// 将口味列表value字符串转为json数组if(dishFlavorList.value!=null){dishFlavorList.value.forEach(item => {item.value = JSON.parse(item.value);});}open.value = true;title.value = "修改菜品管理";});
}/** 提交按钮 */
function submitForm() {proxy.$refs["dishRef"].validate(valid => {if (valid) {form.value.dishFlavorList = dishFlavorList.value;// 将口味列表中value通过JSON工具类转为字符串if(form.value.dishFlavorList!=null){form.value.dishFlavorList.forEach(item=>{item.value = JSON.stringify(item.value)})}if (form.value.id != null) {updateDish(form.value).then(response => {proxy.$modal.msgSuccess("修改成功");open.value = false;getList();});} else {addDish(form.value).then(response => {proxy.$modal.msgSuccess("新增成功");open.value = false;getList();});}}});
}/** 删除按钮操作 */
function handleDelete(row) {const _ids = row.id || ids.value;proxy.$modal.confirm('是否确认删除菜品管理编号为"' + _ids + '"的数据项?').then(function() {return delDish(_ids);}).then(() => {getList();proxy.$modal.msgSuccess("删除成功");}).catch(() => {});
}/** 菜品口味关系序号 */
function rowDishFlavorIndex({ row, rowIndex }) {row.index = rowIndex + 1;
}/** 菜品口味关系添加按钮操作 */
function handleAddDishFlavor() {let obj = {};obj.name = "";obj.value = "";dishFlavorList.value.push(obj);
}/** 菜品口味关系删除按钮操作 */
function handleDeleteDishFlavor() {if (checkedDishFlavor.value.length == 0) {proxy.$modal.msgError("请先选择要删除的菜品口味关系数据");} else {const dishFlavors = dishFlavorList.value;const checkedDishFlavors = checkedDishFlavor.value;dishFlavorList.value = dishFlavors.filter(function(item) {return checkedDishFlavors.indexOf(item.index) == -1});}
}/** 复选框选中数据 */
function handleDishFlavorSelectionChange(selection) {checkedDishFlavor.value = selection.map(item => item.index)
}/** 导出按钮操作 */
function handleExport() {proxy.download('merchant/dish/export', {...queryParams.value}, `dish_${new Date().getTime()}.xlsx`)
}getList();
</script>

五、页面调整(修改logo、系统名称、删除不需要部分)

目标:
在这里插入图片描述

1.浏览器标签页icon、标题

  • 修改标题:
    在这里插入图片描述
    修改标题涉及的文件路径如下:
    在这里插入图片描述
  • 修改logo
    在这里插入图片描述

2.系统页面中的logo、标题

  • 修改logo
    在这里插入图片描述
  • 修改标题
    在这里插入图片描述

3.去除源码&文档

在这里插入图片描述

4.主题和自定义图标

  • 定义主题颜色
    在这里插入图片描述
  • 定义菜单图标
    *在这里插入图片描述*

5.登录页面中标题、背景图

  • 修改标题
    在这里插入图片描述

  • 修改背景图
    添加背景图
    在这里插入图片描述
    修改背景图路径
    在这里插入图片描述

  • 效果
    在这里插入图片描述
    我们发现,登录界面挡住了小车,修改css样式:

.login {display: flex;justify-content: flex-end; /* 修改为居右对齐 */align-items: center;height: 100%;padding-right: 20%; /* 添加右内边距以保持20%间距 */background-image: url("../assets/images/login-background1.jpg");background-size: cover;
}

结果如下图:
在这里插入图片描述

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

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

相关文章

Matlab|【免费】含氢气氨气综合能源系统优化调度

目录 主要内容 部分代码 结果一览 下载链接 主要内容 该程序参考《_基于氨储能技术的电转氨耦合风–光–火综合能源系统双层优化调度》模型&#xff0c;对制氨工厂、风力发电、电制氢、燃气轮机、火电机组等主体进行建模分析&#xff0c;以火电机组启停成本、煤耗…

VS Code修改菜单栏字体大小

修改方法 打开VS Code&#xff0c;快捷键 CtrlShiftP&#xff0c;在弹出的输入框中输入 setting&#xff0c;找到带有JSON的一项&#xff0c;如图所示&#xff1a; 原文链接 window.zoomLevel 前后变化 终端字体大小 File -> Preferences -> Settings -> Features…

海外短剧系统:一扇窥探多元文化的奇妙之窗

随着全球化的推进&#xff0c;文化交流的壁垒逐渐消融&#xff0c;我们得以更加便捷地领略到世界各地的独特风情。在这一背景下&#xff0c;海外短剧系统应运而生&#xff0c;它如同一扇扇虚拟的窗户&#xff0c;将我们带入不同国家、不同民族、不同文化的世界&#xff0c;让我…

Spark算法之ALS模型(附Scala代码)

Spark算法之ALS模型&#xff08;附Scala代码&#xff09; 在大数据时代&#xff0c;个性化推荐系统已成为连接用户与信息的桥梁&#xff0c;而算法则是构建这一桥梁的基石。Apache Spark&#xff0c;作为一款强大的分布式计算系统&#xff0c;提供了丰富的机器学习库&#xff…

比特币生态系统的现状与流动性提升的新路径

自2009年中本聪发布比特币白皮书以来&#xff0c;比特币一直被誉为“数字黄金”&#xff0c;在加密货币领域占据着不可动摇的地位。其去中心化、稀缺性和安全性&#xff0c;增强了其作为长期价值储存工具的吸引力。 相比之下&#xff0c;以太坊自2015年问世以来&#xff0c;凭…

超低排放标准

据朗观视觉小编了解发现&#xff0c;超低排放标准作为衡量一个行业或企业环保水平的重要指标&#xff0c;越来越受到社会各界的关注。本文将深入探讨超低排放标准的内涵、实施意义以及未来展望。 一、超低排放标准的定义 超低排放标准&#xff0c;是指在特定工业生产过程中&am…

视频共享融合赋能平台LntonCVS统一视频接入平台数字化升级医疗体系

医疗健康事关国计民生&#xff0c;然而&#xff0c;当前我国医疗水平的地区发展不平衡、医疗资源分布不均和医疗信息系统老化等问题&#xff0c;制约了整体服务能力和水平的提升。视频融合云平台作为推动数字医疗的关键工具&#xff0c;在医疗领域的广泛应用和普及&#xff0c;…

Oracle - 数据库打补丁实践

原文&#xff1a;https://www.cnblogs.com/ddzj01/p/12097467.html 一、概述 本文将介绍如何给oracle数据库打最新补丁&#xff0c;数据库版本为11.2.0.4单实例&#xff0c;操作系统为redhat6.5 二、下载相关升级包 1. 登录MOS&#xff0c;查阅(ID 2118136.2)&#xff0c;下载…

如何快速把一篇文章或企业介绍变为视频?

随着科技和数字化的不断发展&#xff0c;企业的营销手段也在不断变革。尤其对于产品宣传来说&#xff0c;用生动的视觉语言直观地展示产品特点和优势&#xff0c;能够彰显企业实力&#xff0c;让社会不同层面的人士对企业产生正面、良好的印象&#xff0c;从而建立对该企业的好…

开发技术-Java集合(List)删除元素的几种方式

文章目录 1. 错误的删除2. 正确的方法2.1 倒叙删除2.2 迭代器删除2.3 removeAll() 删除2.4 removeIf() 最简单的删除 3. 总结 1. 错误的删除 在写代码时&#xff0c;想将其中的一个元素删除&#xff0c;就遍历了 list &#xff0c;使用了 remove()&#xff0c;发现效果并不是想…

CircuitBreaker断路器-Resilience4j

目录 背景分布式架构面临的问题&#xff1a;服务雪崩如何解决&#xff1f; CircuitBreakerResilience4jCircuitBreaker 服务熔断服务降级三种状态转换例子参数配置案例demo作业 BulkHead隔离特性SemaphoreBulkhead使用了信号量FixedThreadPoolBulkhead使用了有界队列和固定大小…

Opencv中RotatedRect和ellipse的角度方向

版本&#xff1a;opencv-4.7.0-windows Opencv中&#xff0c;大多数时候&#xff0c;逆时针旋转是正方向&#xff0c;但在RotatedRect和ellipse中&#xff0c;顺时针旋转是正方向。 //RotatedRect的角度参数是顺时针为正方向 RotatedRect(const Point2f& center, const Si…

OpenCV练习(2)图像校正

1、傅里叶变换 霍夫变换 直线 角度 旋转2、边缘检测 霍夫变换 直线角度 旋转3、四点透视 角度 旋转4、检测矩形轮廓 角度 旋转 1.目的 实现类似全能扫面王的图像校正功能 2. 基于轮廓提取和透射变换 基于轮廓提取和透射变换的矫正算法更适用于车牌、身份证、人民…

机器人控制系列教程之动力学建模(1)

简介 机器人动力学是对机器人机构的力和运动之间关系与平衡进行研究的学科。机器人动力学是以机器人运动为基础&#xff0c;研究在运动过程中连杆与连杆之间、连杆与工件之间力或力矩等关系。 分类&#xff1a; 根据研究方向的不同&#xff0c;机器人的动力学分析也分为正、逆…

【Qt之·类QTableWidget】

系列文章目录 文章目录 前言一、常用属性二、成员函数2.1 左上角空白区域 三、实例演示总结 前言 一、常用属性 二、成员函数 方法描述selectRow选中行removeRow移除行insertRow插入行rowCount总行数 2.1 左上角空白区域 QTableCornerButton即不属于列表头&#xff0c;也不…

标准版绑定完手机号页面不跳转问题修复

标准版在不登录的情况下&#xff0c;从商品进去下单的时候跳出来登录并绑定手机号&#xff0c;绑定完手机号页面不跳转问题 修改教程如下&#xff1a; 文件目录&#xff1a;template/uni-app/pages/users/binding_phone/index.vue 加如图内容&#xff0c;然后重新打包

分享一套基于SSM的美食推荐管理系统(源码+文档+部署)

大家好&#xff0c;今天给大家分享一套基于SSM的美食推荐管理系统 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringSpringMvcMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 博主介绍&#xff1a; 一名Java全栈工程师&#xff0c;专注于Jav…

3D Web轻量引擎HOOPS Web Platform赋能AEC行业数字化,高效渲染与多格式支持!

在建筑、工程和施工&#xff08;AEC&#xff09;行业&#xff0c;数字化转型和高效协作正变得越来越重要。为应对日益复杂的项目需求和不断提升的质量标准&#xff0c;AEC企业需要一种强大的工具来实现高效的3D可视化和数据管理。HOOPS Web Platform作为一款综合性3D开发平台&a…

床上用品跨境电商:拥有沃尔玛1P特权的商家享有哪些显著优势?

在全球化的背景下&#xff0c;跨境电商对床上用品行业至关重要。沃尔玛因其品牌影响力、客户资源及物流体系在跨境电商平台中脱颖而出。拥有沃尔玛1P特权的商家享有更多曝光机会和独家优惠。那么&#xff0c;这些特权商家具体有哪些优势呢? 沃尔玛1P特权商家在曝光率上具有显著…

Ubuntu 20.04安装中文输入法出错:gnome-user-docs-zh-hans安装失败

问题&#xff1a;Ubuntu20.04安装中文输入法出错&#xff1a;gnome-user-docs-zh-hans安装失败 现象&#xff1a; 打开language Support页面的时候&#xff0c;提示install依赖的文件 这个过程中会弹窗提示: The following packages have unmet dependencies:gnome-user-doc…