产品品牌CRUD

文章目录

    • 1.renren-generator生成CRUD
        • 1.数据库表设计
          • 1.数据表设计
          • 2.分析
        • 2.代码生成器生成crud
          • 1.查看generator.properties(不需要修改)
          • 2.修改application.yml 连接的数据库修改为云数据库
          • 3.启动renren-generator模块
          • 4.浏览器访问 http://localhost:81/
          • 5.选择commodity_brand表,点击生成代码,并将其解压
          • 6.将这个main目录覆盖该模块的main目录,一旦有提示是否要覆盖,取消,手动调整
        • 3.解决报错
          • 1.BrandController.java 的RequiresPermissions报错 全部注释掉即可
          • 2.检查生成的代码
            • 1.表字段
            • 2.BrandEntity.java的isshow字段有问题,应该是isShow(不用改)
            • 3.BrandDao.java
            • 4.BrandDao.xml 修改属性isShow(不用改)
            • 5.BrandService.java
            • 6.BrandServiceImpl.java
        • 4.postman测试CRUD
          • 1.启动项目
          • 2.测试 http://localhost:9091/commodity/brand/list
          • 3.测试 http://localhost:9091/commodity/brand/info/1
          • 4.测试 http://localhost:9091/commodity/brand/save
          • 5.测试 http://localhost:9091/commodity/brand/update
          • 6.测试 http://localhost:9091/commodity/brand/delete
    • 2.配置新页面,确保前后端连通
        • 1.创建子菜单
          • 1.启动renren-fast模块,登录系统
          • 2.创建子菜单 品牌管理
          • 3.刷新查看URL,此时应该是会访问到Vue的src/views/modules/commodity/brand.vue
          • 4.将代码生成器生成的 brand.vue 和 brand-add-or-update.vue 放到前端的 src/views/modules/commodity目录下
          • 5.前端点击品牌管理,此时应该在转圈
          • 6.修改brand.vue的发送请求部分
            • 1.找到这个地方
            • 2.使用环境变量+资源路径的方式修改请求
            • 3.查看页面请求到了,但是500错误
            • 4.查看后台是is_show字段的问题
            • 5.修改BrandEntity.java和BrandDao.xml的字段为isshow,然后重启
            • 6.查看菜单,成功访问
            • 7.原因
            • 8.将brand.vue的其他请求也修改成这样的格式,然后点击修改和删除测试
          • 7.取消ESLint检测
          • 8.打开权限检测,会出现添加和批量删除按钮
            • 1.修改src/utils/index.js 使其一直返回true
            • 2.出现新增和批量删除按钮
          • 9.重启后端项目,进行测试
            • 1.新增
            • 2.修改
            • 3.删除
            • 4.新增两个,批量删除
          • 10.完成简单分页查询
            • 1.查看 brand.vue 的请求数据
            • 2.找到后端的 com.sun.sunliving.commodity.service.impl.BrandServiceImpl.java
            • 3.修改查询条件
            • 4.测试
            • 5.恢复,以后有更好的解决方案
    • 3.项目部署
        • 1.后端区分多环境
          • 1.sunliving-commodity模块 数据库为云数据库,上下文路径也设置了
          • 2.renren-fast模块不用动
          • 3.整体打包
            • 1.clean
            • 2.package
            • 3.进入sunliving-commodity模块的target目录执行 java -jar sunliving-commodity-1.0-SNAPSHOT.jar
            • 4.设置application.yml的profiles为生产环境 prod
            • 5.重新打包然后执行java -jar 这次成功了
            • 6.ctrl + c 退出
        • 2.前端区分多环境(修改请求)
          • 1.自己的请求是以环境变量 +资源路径的形式,脚手架的请求也修改过
          • 2.项目根目录下执行 npm run build(默认是生产环境)
          • 3.查看生成的dist目录
        • 3.前后端部署
          • 1.将前端dist目录下的文件放到网站根目录
          • 2.访问查看
          • 3.将sunliving-commodity-1.0-SNAPSHOT.jar上传到网站并且替换原来的jar包
          • 4.再次访问项目
    • 4.启用Switch开关控件
        • 1.Switch控件部署
          • 1.找到Switch控件
          • 2.部署控件到项目中
            • 1.查看el-table文档的自定义列模板
            • 2.将选中的部分粘贴到显示的那个列
            • 3.确实可以显示自定义图标
            • 4.引入el-switch,但是只要修改一个按钮,其他的按钮都会跟着动
            • 5.跟当前行的isshow属性双向绑定即可
            • 6.完整的 switch 控件
            • 7.方法池编写changeIsShow
          • 3.测试
            • 1.全不显示
            • 2.数据库信息
        • 2.自定义删除和批量删除的提示信息
          • 1.删除时新增一个传递的参数name
          • 2.修改deleteHandle方法
          • 3.测试

1.renren-generator生成CRUD

1.数据库表设计
1.数据表设计
use sunliving_commodity;CREATE TABLE `commodity_brand`
(id          BIGINT NOT NULL AUTO_INCREMENT COMMENT 'id',`name`      CHAR(50) COMMENT '品牌名',logo        VARCHAR(1200) COMMENT 'logo',description LONGTEXT COMMENT '说明',isShow      TINYINT COMMENT '显示',first_letter CHAR (1) COMMENT '检索首字母',sort        INT COMMENT '排序',PRIMARY KEY (id)
) CHARSET = utf8mb4 COMMENT ='家居品牌';INSERT INTO`commodity_brand` (id,`name`, logo,description,isShow,first_letter,sort)
VALUES(1, '海信','','',1,'',NULL);SELECT * FROM `commodity_brand`;
2.分析
  • sort字段由于其不确定性太强,所以就设置成空
  • 一个品牌可能会有多种产品,所以目前暂时不与商品表关联,以后使用更灵活的方式
2.代码生成器生成crud
1.查看generator.properties(不需要修改)

image-20240412191507762

2.修改application.yml 连接的数据库修改为云数据库
3.启动renren-generator模块

image-20240412191714735

4.浏览器访问 http://localhost:81/

image-20240412192023685

5.选择commodity_brand表,点击生成代码,并将其解压

image-20240412192713318

6.将这个main目录覆盖该模块的main目录,一旦有提示是否要覆盖,取消,手动调整

image-20240412192944700

image-20240412193015064

3.解决报错
1.BrandController.java 的RequiresPermissions报错 全部注释掉即可

image-20240412193215484

2.检查生成的代码
1.表字段

image-20240412194227961

2.BrandEntity.java的isshow字段有问题,应该是isShow(不用改)
  • MyBatis默认自动驼峰命名

image-20240412194359974

3.BrandDao.java
  • 依赖注入,继承BaseMapper,操作BrandEntity

image-20240412194555575

4.BrandDao.xml 修改属性isShow(不用改)
  • application.yml扫描

image-20240412195204760

5.BrandService.java
  • 继承IService接口对BrandEntity进行操作

image-20240412195305510

6.BrandServiceImpl.java
  • 实现BrandService接口,继承ServiceImpl,使用BrandDao对BrandEntity进行操作

image-20240412195457863

4.postman测试CRUD
1.启动项目

image-20240412195850034

2.测试 http://localhost:9091/commodity/brand/list

image-20240412200213836

3.测试 http://localhost:9091/commodity/brand/info/1

image-20240412200331205

4.测试 http://localhost:9091/commodity/brand/save

image-20240412200551168

image-20240412200615342

image-20240412200633017

5.测试 http://localhost:9091/commodity/brand/update

image-20240412201000304

image-20240412201021230

6.测试 http://localhost:9091/commodity/brand/delete

image-20240412201402382

image-20240412201415278

2.配置新页面,确保前后端连通

1.创建子菜单
1.启动renren-fast模块,登录系统

image-20240412203153769

2.创建子菜单 品牌管理

image-20240412203856714

image-20240412203825150

3.刷新查看URL,此时应该是会访问到Vue的src/views/modules/commodity/brand.vue

image-20240412203947253

4.将代码生成器生成的 brand.vue 和 brand-add-or-update.vue 放到前端的 src/views/modules/commodity目录下

image-20240412205837768

image-20240412205914106

5.前端点击品牌管理,此时应该在转圈

image-20240412205956832

6.修改brand.vue的发送请求部分
1.找到这个地方

image-20240412210210180

2.使用环境变量+资源路径的方式修改请求

image-20240412211436995

3.查看页面请求到了,但是500错误

image-20240412211548322

4.查看后台是is_show字段的问题

image-20240412211626211

5.修改BrandEntity.java和BrandDao.xml的字段为isshow,然后重启

image-20240412211710524

image-20240412211726785

6.查看菜单,成功访问

image-20240412211912695

7.原因
  • 表中的字段写的是isShow,然后MyBatisPlus默认开启了自动驼峰命名法
  • 我以为在实体类中应该也是isShow了,但是在实际操作数据库的时候会变成is_show
  • 在开启自动驼峰命名法的前提下如果数据库中的字段是驼峰isShow的话,那么在项目中就应该是isshow
8.将brand.vue的其他请求也修改成这样的格式,然后点击修改和删除测试

image-20240412212909427

image-20240412212935078

7.取消ESLint检测
8.打开权限检测,会出现添加和批量删除按钮
1.修改src/utils/index.js 使其一直返回true

image-20240413091950739

2.出现新增和批量删除按钮

image-20240413092023017

9.重启后端项目,进行测试
1.新增

image-20240413092323655

image-20240413092343639

2.修改

image-20240413092423699

image-20240413092433880

image-20240413092447434

3.删除

image-20240413092507119

4.新增两个,批量删除

image-20240413092554235

image-20240413092601031

image-20240413092612202

10.完成简单分页查询
1.查看 brand.vue 的请求数据

image-20240413094551578

2.找到后端的 com.sun.sunliving.commodity.service.impl.BrandServiceImpl.java

image-20240413094751580

3.修改查询条件

image-20240413095305546

4.测试

image-20240413095405748

5.恢复,以后有更好的解决方案

3.项目部署

1.后端区分多环境
1.sunliving-commodity模块 数据库为云数据库,上下文路径也设置了

image-20240412213419094

2.renren-fast模块不用动
3.整体打包
1.clean

image-20240412213551640

2.package

image-20240412213604270

image-20240412213629831

3.进入sunliving-commodity模块的target目录执行 java -jar sunliving-commodity-1.0-SNAPSHOT.jar
  • 端口9091,上下文路径为空,说明没有设置为生产环境!

image-20240412213847755

4.设置application.yml的profiles为生产环境 prod
5.重新打包然后执行java -jar 这次成功了

image-20240412214224582

6.ctrl + c 退出
2.前端区分多环境(修改请求)
1.自己的请求是以环境变量 +资源路径的形式,脚手架的请求也修改过
2.项目根目录下执行 npm run build(默认是生产环境)

image-20240412215348834

3.查看生成的dist目录

image-20240412215528521

3.前后端部署
1.将前端dist目录下的文件放到网站根目录

image-20240412220207310

2.访问查看

image-20240412221023576

3.将sunliving-commodity-1.0-SNAPSHOT.jar上传到网站并且替换原来的jar包
4.再次访问项目

image-20240412221619188

image-20240412221636322

image-20240412221642530

4.启用Switch开关控件

1.Switch控件部署
1.找到Switch控件

https://element.eleme.cn/#/zh-CN/component/switch

image-20240413100307462

2.部署控件到项目中
1.查看el-table文档的自定义列模板

image-20240413101156513

2.将选中的部分粘贴到显示的那个列

image-20240413101346786

3.确实可以显示自定义图标

image-20240413101416489

4.引入el-switch,但是只要修改一个按钮,其他的按钮都会跟着动

image-20240413101659178

image-20240413101703830

5.跟当前行的isshow属性双向绑定即可

image-20240413102221339

6.完整的 switch 控件
  • :active-value="1"表示激活状态为1
  • :inactive-value="0"表示非激活状态为0
  • 注意这里一定要加冒号,因为绑定的是num值
      <el-table-columnprop="isshow"header-align="center"align="center"label="显示"><template slot-scope="scope"><el-switchv-model="scope.row.isshow"@change="changeIsShow(scope.row)":active-value="1":inactive-value="0"active-color="#13ce66"inactive-color="#ff4949"></el-switch></template></el-table-column>
7.方法池编写changeIsShow
      // 根据switch开关改变是否显示changeIsShow (row) {this.$http({// url: this.$http.adornUrl('/commodity/brand/update'),url: process.env.BASEPATH + '/commodity/brand/update',method: 'post',data: this.$http.adornData({id: row.id,isshow: row.isshow}, false)}).then(({data}) => {if (data && data.code === 0) {this.getDataList()this.$message({message: '操作成功',type: 'success',duration: 1500})} else {this.$message.error(data.msg)}})}
3.测试
1.全不显示

image-20240413112546694

2.数据库信息

image-20240413112607267

2.自定义删除和批量删除的提示信息
1.删除时新增一个传递的参数name

image-20240413114417476

2.修改deleteHandle方法

image-20240413114521176

3.测试

image-20240413114541464

image-20240413114549997

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

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

相关文章

解决使用Vue.js前端与Flask后端API交互时跨源资源共享问题

我在使用flask以及Vue做一个项目时遇到了Vue前端与Flask后端API交互的问题就是前端获取不到后端返回的数据&#xff0c;报错&#xff1a; 上网查说是跨域问题&#xff0c;于是找了一些解决办法&#xff0c;就是可以通过设置响应头的 Access-Control-Allow-Origin 字段来允许所有…

易货模式:引领交易新潮流,实现资源高效利用

随着全球经济的繁荣和科技的日新月异&#xff0c;传统的交易模式正面临革新。在追求高效、便捷与环保的当下&#xff0c;易货模式作为一种新兴的交易方式&#xff0c;逐渐崭露头角&#xff0c;受到越来越多人的青睐。 易货模式&#xff0c;简而言之&#xff0c;就是通过平台或在…

知乎广告推广投放流程以及价格?

知乎作为一个拥有庞大高质量用户群体的知识分享平台&#xff0c;成为了众多品牌不可忽视的广告投放渠道。知乎不仅汇聚了各行各业的专业人士&#xff0c;其独特的社区氛围也为品牌提供了精准触达目标受众的机会。知乎广告推广的投放流程、费用标准&#xff0c;云衔科技提供的专…

刷代码随想录有感(65):回溯算法——组合问题

题干&#xff1a; 代码&#xff1a; class Solution { public:vector<vector<int>> res;vector<int> tmp;void backtracking(int n, int k, int start){if(tmp.size() k){res.push_back(tmp);return;}for(int i start; i < n; i){tmp.push_back(i);bac…

全栈开发之路——前端篇(9)插槽、常用api和全局api

全栈开发一条龙——前端篇 第一篇&#xff1a;框架确定、ide设置与项目创建 第二篇&#xff1a;介绍项目文件意义、组件结构与导入以及setup的引入。 第三篇&#xff1a;setup语法&#xff0c;设置响应式数据。 第四篇&#xff1a;数据绑定、计算属性和watch监视 第五篇 : 组件…

Transformers中加载预训练模型的过程剖析(一)

使用HuggingFace的Transformers库加载预训练模型来处理下游深度学习任务很是方便,然而加载预训练模型的方法多种多样且过程比较隐蔽,这在一定程度上会给人带来困惑。因此,本篇文章主要讲一下使用不同方法加载本地预训练模型的区别、加载预训练模型及其配置的过程,藉此做个记…

计算机组成原理(超详解!!) 第八节 总线系统

1.总线的概念和结构形态 1.总线&#xff08;BUS&#xff09;的基本概念 是构成计算机系统的互联机构&#xff0c;是多个系统功能部件&#xff08;运算器、控制器、存储器、输入/输出设备&#xff09;之间进行数据传送的公共通路。 由传输信息的电路和管理信息传输的协议组成…

【数据结构】栈和队列专题

前言 上篇博客我们讨论了栈和队列的有关结构&#xff0c;本篇博客我们继续来讨论有关栈和队列习题 这些题算是经典了 &#x1f493; 个人主页&#xff1a;小张同学zkf ⏩ 文章专栏&#xff1a;数据结构 若有问题 评论区见&#x1f4dd; &#x1f389;欢迎大家点赞&#x1f44d…

Linux内核发送网络数据

前言 我们开始今天对 Linux 内核⽹络发送过程的深度剖析。还是按照我们之前的传统&#xff0c;先从⼀段代码作为切⼊。 上述代码中&#xff0c;调⽤ send 之后内核是怎么样把数据包发送出去的。本⽂基于Linux 3.10&#xff0c;⽹卡驱动采⽤Intel的igb举例。 基础框架 我们看…

栅格地图、障碍物地图与膨胀地图(障碍物地图(三)写一张障碍物地图)

花了不少时间看完了障碍物地图的大致思路&#xff0c;这里简单根据前面的思路来写一个简易版的障碍物地图。 1.订阅一张地图 首先&#xff0c;我们需要一张静态地图作为原始数据&#xff0c;这个我们可以订阅当前的map来获取&#xff1a; void map_test1::MapCallback(const…

财务分析软件怎么选?看这篇就够了

怎么才能选到一款真正能够用于财务分析的软件&#xff1f;且是能够又快又直观地将财务数据情况分析清楚&#xff0c;从不同角度灵活分析财务数据背后的关联的软件&#xff0c;简单来说那得选一款BI财务分析软件。具体哪款BI财务分析软件更合适&#xff1f;那就要从以下几个方面…

几款打工人必备的AI绘图软件工具分享给你!

随着人工智能技术的不断进步&#xff0c;AI绘图软件工具成为了设计师和打工人提升工作效率的得力助手。这些工具不仅能够帮助我们快速完成复杂的绘图任务&#xff0c;还能激发我们的创意灵感。在本文中&#xff0c;我将为大家介绍几款打工人必备的AI绘图软件工具&#xff0c;其…

历史影像的下载办法总结

最近想要下黄河口的历史影像&#xff0c;试验了几个办法&#xff1a; 1&#xff09;参考文献1中的办法&#xff0c;用Global Mapper下载World Imagery Wayback网站的历史数据&#xff0c;能下载从2014年至现在的&#xff1b; 2&#xff09;参考文献1中的办法&#xff0c;用SA…

vue3中教你如何使用指令解决文本的溢出提示

在我们项目开发中,经常会有超长文本溢出提示,未溢出则不提示的场景。 在项目开发中遇到了比较复杂的场景,在一个组织树中,我们使用了el-tree来显示组织树,文字长度不一,太长的显示不全&#xff0c;刚开始我们使用滚动条&#xff0c;结果不好看 后来我们就直接再el-tree中添加el…

iOS copy的正确姿势

参考文章 知识准备&#xff08;理解堆栈&#xff09; 堆区&#xff1a; 程序员管理 若程序员不释放&#xff0c;由os释放不同于数据结构中的堆&#xff0c;堆区的结构类似于数据结构中的链表栈区&#xff1a; 由编译器来管理 存放函数参数值&#xff0c;局部变量的值等结构类似…

Facebook消息群发脚本的制作思路!

在数字化社交日益盛行的今天&#xff0c;Facebook作为全球最大的社交平台之一&#xff0c;为企业和个人提供了广阔的交流与合作空间。 然而&#xff0c;手动向大量用户发送消息既耗时又低效&#xff0c;因此&#xff0c;开发一款能够自动群发消息的脚本成为了许多人的需求&…

【正点原子Linux连载】 第四十二章 多点电容触摸屏实验摘自【正点原子】ATK-DLRK3568嵌入式Linux驱动开发指南

1&#xff09;实验平台&#xff1a;正点原子ATK-DLRK3568开发板 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id731866264428 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/docs/boards/xiaoxitongban 第四十…

汇昌联信:拼多多网店该如何开店?

拼多多网店的开设流程并不复杂&#xff0c;但需要细心和耐心去完成每一步。下面将详细阐述如何开设一家拼多多网店。 一、选择商品与定位 开设拼多多网店的第一步是确定你要销售的商品类型&#xff0c;这决定了你的目标客户群体和市场定位。你需要了解这些商品的市场需求、竞争…

CAST: Cross-Attention in Space and Time for Video Action Recognition

标题&#xff1a;CAST: 时空交叉注意力网络用于视频动作识别 原文链接&#xff1a;2311.18825v1 (arxiv.org)https://arxiv.org/pdf/2311.18825v1 源码链接&#xff1a;GitHub - KHU-VLL/CASThttps://github.com/KHU-VLL/CAST 发表&#xff1a;NeurIPS-2023&#xff08;CCF A…