增删改查文档
列表 :
列表包含 :
模糊查找 + 分页
列表jsp页面 :
一 :导入外部文件
(举例 : 用户点进来就可以看到菜单,这是预加载属于,使用文档就绪函数实现)
二 : body 上
① : 文档就绪函数 ${ function()
//获取条件查询的字段
//组装对象
//调用文档就绪函数
}
② : 封装ajax方法{
$.ajax({
- 请求路径
- 请求方法
- 数据传递
- 解析
- 成功回调函数
- 打印
- 因为有分页添加分页
let arr = res.data; //首页
let prevPage = res.prevPage; //上一页
let nextPage = res.nextPage; //下一页
let totalPage = res.totalPage; //尾页
3.清空表
4.追加表头
5.使用循环追加数据
(因为有分页 用上面的arr)
for (let x of arr)
- 在循环外面追加分页按钮 colspan居中
<td colspan="100">
<input type="button" value="首页" οnclick="doPage(1)">
- 失败回调函数{
给出提示
}
})
}
body 中间
三 : 搜索框 inp
四 : 搜索按钮 button
五 : 列表 table
六 : body 下写脚本 script
- 给搜索按钮绑定一个点击事件{
//获取条件查询的字段
//组装对象
//调用文档就绪函数
}
- 分页 给分页写一个function方法{
//获取条件查询的字段
//组装对象
//调用文档就绪函数
//多加一个pageNum
}
Controller:
一 : @WebServlet("/menu/*")
MenuVo menuVo = JSONObject.parseObject(reqInfos, MenuVo.class);
//将转换后的对象传给Service
PageResult<MenuVo> list= service.menuList(menuVo);
//将转换后的结果响应给用户
resp.getWriter().println(JSONObject.toJSONString(list));
//调用到层方法获取所有数据
List<MenuVo> list = dao.menuList(menuVo);
//调用到层方法,获取总条数
int count = dao.getCount(menuVo);
//Integer pageNum, Integer totalNum, Integer pageSize, List<T> data
PageResult<MenuVo> menuVoPageResult = new PageResult<>(menuVo.getPageNum(), count, menuVo.getPageSize(), list);
return menuVoPageResult;
二 : ser {
全局变量
- 接参
- 将json对象转换成java对象
- 将转换后的对象传给service
- 将处理后的结果响应给用户
}
Service:
① : 调用dao层方法获取所有数据 (参数放vo类的)
List<MenuVo> list = dao.menuList(menuVo);
② : 定义总条数的方法
int count = dao.getCount(menuVo);
③ : 点进去分页工具类 调用方法 (将参数粘过来对着写) 得到返回值
④ : 返回返回值
Dao:
一 : 1.定义sql语句 :
- 根据名字模糊查找
- 打印sql语句
- 分页sql语句
sql+=" limit ?,?";
- 分页公式 : 起始下标 = (当前页数 - 1)*条数
int index=(menuVo.getPageNum()-1)*menuVo.getPageSize();
- 分页公式
处理返回结果
添加 :
添加Jsp页面:
一 :导入外部文件
(举例 : 用户点进来就可以看到菜单,这是预加载属于,使用文档就绪函数实现)
二 : body 上
① : 文档就绪函数 ${ function()
//调用下拉框的function方法
//关闭异步
}
② : 封装ajax方法{
$.ajax({
- 请求路径
- 请求方法
- 数据传递
- 解析
- 成功回调函数{
① : 打印
② : 循环追加数据{
//追加数据 :
1.是下拉框的数据
2.头追的是外键的ID
3.value : 外键的ID
4.option中间方法的是 外键的名字
for (let x of res) {
//追加数据
$("#typeId").append(`
<option value="\${x.typeId}">\${x.typeName}</option>
- 失败回调函数 { 给出提示 }
三 : body 中间
- 添加文本框
文本框用 : text 下拉框 : <select> <option>
下拉框的ID给的是主表里外键的字段 追加的是外键的主键和外面的名称字段
下俩框示例 : 类型ID: <select id="typeId">
<option value="">请选择</option>
</select><br>
图片实例 :
上传图片: <img src="" alt="" width="35" height="35" id="imgUrl">
<input type="file" id="file" onchange="showImg(this)">
- 添加的按钮
- Body下面写 <script>
①先给图片绑定点击事件
- 获取选中图片的路径
- 创建文件阅读器
- 读取文件图片路径
- 加载给src内容给service赋值{
- 给图片赋值
}
图片绑定事件案例
function showImg(obj) {
//获取选中图片的路径(和绑定事件里的实参使用一个单词) 加载图片内容给Service赋值
let file = obj.files[0];
//创建文件阅读器
let reader = new FileReader();
//读取图片路径
reader.readAsDataURL(file);
//加载src内容给Service赋值
reader.onload=function () {
//给图片赋值
$("#imgUrl").attr("src",reader.result)
}
}
- 给添加按钮绑定单击事件
①将res的路径给imgUrl 添加的点击事件里.ajax外
②创建formDate对象
③获取选中的图片
④将图片放到创建的formData中
⑤图片的ajax{
在成功回调函数里:将res的路径给imgUrl
}
⑥取值 (添加框字段的值)
⑦非空校验
⑧组装对象
⑨添加的ajax{
在成功回调函数里:添加后跳转list.jsp}
FileController
一 : 上传图片的方法 (上传图片单词 : upload)
①调用图片方法
②将处理后的结果响应给用户
上传图片示例 :
protected void upload(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//调用图片方法
String image = UploadUtil.uploadImage(req, resp);
//将处理后的结果响应给用户
resp.getWriter().println(JSONObject.toJSONString(image));
}
二:展示图片方法 showIng
①传参
②使用工具类调用方法
展示图片方法示例 :
protected void showImg(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//传参
String imgUrl = req.getParameter("imgUrl");
//使用工具类调用方法
UploadUtil.showImg(imgUrl,resp);
}
Controller :
上传图片的方法 : upload
1.调用工具类图片方法
2.响应
展示图片的方法 :showImg
3.传参
4.使用工具类调用方法
添加方法 {
- 接参
- 将json对象转换成Java对象
- 将转换后的对象传给service
- 处理返回值(返200)
}
Service :
①不需要显示的字段设置默认值
②调用dao层方法 没有返回值直接走
Dao :
- : 定义sql
- : 执行sql
修改 :
删除 :
相关文章:
增删改查文档
列表 : 列表包含 : 模糊查找 分页 列表jsp页面 : 一 :导入外部文件 (举例 : 用户点进来就可以看到菜单,这是预加载属于,使用文档就绪函数实现) 二 : body 上 ① : 文档就绪函数 ${ function() //获取条件查询的字段 //组装对象 //调用文档就绪函数 } ② : 封装ajax方…...
C语言蓝桥杯2023年省赛真题
文章目录 持续更新中...第一题题目描述输入格式输出格式样例输出提示 2 第二题题目描述 第三题题目描述输入格式输出格式样例输入样例输出 第四题题目描述输入格式输出格式样例输入样例输出提示 第四题题目描述输入格式输出格式样例输入样例输出提示 第五题题目描述输入格式输出…...
Python迭代器-大数据量的处理
一 生成器的实际使用(大量数据的导出) #分批导出数据然后分批写入excel import pandas as pd import openpyxl from openpyxl.utils.dataframe import dataframe_to_rowsdef execute_query(query):# 假设这是执行 SQL 查询的函数# 返回查询结果passdef …...
自动化包括态交互与感交互,而智能化包括势交互与知交互
“自动化包括态交互与感交互,而智能化包括势交互与知交互”交互框架将交互过程划分为不同类型,有助于更清晰地理解自动化和智能化的本质及其在未来agent应用中的差异与联系。 1. 自动化:态交互与感交互 自动化主要关注的是高效、无差错地执行…...

VideoBooth: Diffusion-based Video Generation with Image Prompts
VideoBooth: Diffusion-based Video Generation with Image Prompts 概括 文章提出了一个视频生成模型VideoBooth,输入一张图片和一个文本提示词,即可输出保持图片中物体且符合文本提示词要求的视频。 方法 粗-细两阶段设计:1)…...

模拟简单的iOT工作流
没有实际接触过iOT的流程,应该实际使用比这个接口返回要复杂,只是演示~希望能参与实际的接口接入,而不是只展示个假数据。 启动RabbitQ 使用的是3.8.5 启动命令 RabbitMQ Service - start RabbitMQ Command Prompt rabbitmqctl start_app …...
C++学习0.2: RAII
引用: 【代码质量】RAII在C编程中的必要性_raii 在c中的重要性-CSDN博客 C RAII典型应用之lock_guard和unique_lock模板_raii lock-CSDN博客 前言: 常用的线程间同步/通信(IPC)方式有锁(互斥锁、读写锁、自旋锁)、…...

k8s,进一步理解Pod
比如,凡是调度、网络、存储,以及安全相关的属性,基本上是Pod 级别的。 这些属性的共同特征是,它们描述的是“机器”这个整体,而不是里面运行的“程序”。比如,配置这个“机器”的网卡(即&#…...

MFC图形函数学习13——在图形界面输出文字
本篇是图形函数学习的最后一篇,相关内容暂告一段落。 在图形界面输出文字,涉及文字字体、大小、颜色、背景、显示等问题,完成这些需要系列函数的支持。下面做简要介绍。 一、输出文本函数 原型:virtual BOOL te…...

【Canvas与雷达】点鼠标可暂停金边蓝屏雷达显示屏
【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>点鼠标可暂停金边蓝屏雷达显示屏 Draft1</title><style typ…...
React第十二节组件之间通讯之发布订阅模式(使用pubsub-js插件)
组件之间通讯常用方案 1、通过props 2、通过context 3、通过发布订阅模式 4、通过Redux 后面会有专栏介绍 1、安装 pubsub-js 插件 yarn add pubsub-js 常用的事件 a、发布事件:传入一个自定义事件名称(name),以及要发布的消息内…...

Vue3安装 运行教程
本文是综合了所有vue安装教程而成 更细化 更简略 希望对各位读者有所帮助! Vue安装 1. Vue-cli脚手架安装 安装vue的方式有很多 我们这里选择npm方式安装vue npm方式 npm方式安装vue,详细介绍见下文。 1.node.js安装和配置 安装npm 需要安装note.js&…...
MySQL:约束constraint
约束就是表中数据的限制条件. 表在设计的时候加入约束的目的是为了保证表中记录的完整性和有效性,如用户表有些列的值(手机号)不能为空,有些列的值(身份证号)不能重复。 主键约束(primary key) PK MySQL主…...
使用Rufus制作Ubuntu需要注意
在使用Rufus制作Ubuntu启动盘并进行BIOS设置时,需要注意以下几点: 关闭RST(英特尔 快速存储技术):在BIOS设置中,如果电脑启用了RST功能,需要将其关闭。因为Ubuntu可能无法检测到硬盘&a…...
探索Go语言的高级特性:性能分析与安全性
Go语言性能分析与安全性 引言 Go语言因其高效的并发特性、简洁的语法和强大的工具链而受到广泛欢迎。在实际开发中,性能分析和安全性是需要特别关注的两个方面。本文将深入探讨Go语言中的性能分析工具和安全性考虑,帮助开发者编写高效、安全的Go应用程…...
SearchSploit配合gcc的使用
渗透测试中,SearchSploit是一个非常有用的工具,用于在Exploit数据库中搜索漏洞利用代码。其使用方法如下: 安装SearchSploit:首先确保你的系统中已经安装了Kali Linux,因为SearchSploit是Kali Linux的一部分。如果没有…...

无人机设计:云台挂载!
一、无人机云台挂载设置 安装与固定 将云台固定到无人机的挂载点上,通常需要使用专用的固定架和螺丝等工具。 确保云台与无人机之间的连接牢固,避免在飞行过程中出现松动或脱落的情况。 连接与调试 将云台与无人机之间的连接线缆(如电源…...
Spring Native适用场景、代理使用及测试部署策略
文章目录 1. Spring Native 适用的应用程序2. 在 Spring Native 中使用代理3. 测试和部署 Spring Native 应用测试部署 1. Spring Native 适用的应用程序 微服务:微服务架构中每个服务都相对独立,快速启动时间和较低的资源消耗对于提高部署效率和服务响…...

LeetCode—11. 盛最多水的容器(中等)
题目描述: 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明:…...
第一部分:入门准备 1.欢迎来到新手村 --[JavaScript 新手村:开启编程之旅的第一步]
为什么学习 JavaScript? 学习 JavaScript 有多个重要的理由,它在现代 Web 开发中扮演着不可或缺的角色。以下是几个关键原因: 1. 广泛的应用 JavaScript 是唯一可以在浏览器端直接运行的编程语言,几乎所有的网站和Web应用都使用…...

python打卡day49
知识点回顾: 通道注意力模块复习空间注意力模块CBAM的定义 作业:尝试对今天的模型检查参数数目,并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...

Xshell远程连接Kali(默认 | 私钥)Note版
前言:xshell远程连接,私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...
Linux简单的操作
ls ls 查看当前目录 ll 查看详细内容 ls -a 查看所有的内容 ls --help 查看方法文档 pwd pwd 查看当前路径 cd cd 转路径 cd .. 转上一级路径 cd 名 转换路径 …...

屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!
5月28日,中天合创屋面分布式光伏发电项目顺利并网发电,该项目位于内蒙古自治区鄂尔多斯市乌审旗,项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站,总装机容量为9.96MWp。 项目投运后,每年可节约标煤3670…...

PL0语法,分析器实现!
简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...

day36-多路IO复用
一、基本概念 (服务器多客户端模型) 定义:单线程或单进程同时监测若干个文件描述符是否可以执行IO操作的能力 作用:应用程序通常需要处理来自多条事件流中的事件,比如我现在用的电脑,需要同时处理键盘鼠标…...

leetcode_69.x的平方根
题目如下 : 看到题 ,我们最原始的想法就是暴力解决: for(long long i 0;i<INT_MAX;i){if(i*ix){return i;}else if((i*i>x)&&((i-1)*(i-1)<x)){return i-1;}}我们直接开始遍历,我们是整数的平方根,所以我们分两…...

基于小程序老人监护管理系统源码数据库文档
摘 要 近年来,随着我国人口老龄化问题日益严重,独居和居住养老机构的的老年人数量越来越多。而随着老年人数量的逐步增长,随之而来的是日益突出的老年人问题,尤其是老年人的健康问题,尤其是老年人产生健康问题后&…...

NineData数据库DevOps功能全面支持百度智能云向量数据库 VectorDB,助力企业 AI 应用高效落地
NineData 的数据库 DevOps 解决方案已完成对百度智能云向量数据库 VectorDB 的全链路适配,成为国内首批提供 VectorDB 原生操作能力的服务商。此次合作聚焦 AI 开发核心场景,通过标准化 SQL 工作台与细粒度权限管控两大能力,助力企业安全高效…...

使用homeassistant 插件将tasmota 接入到米家
我写一个一个 将本地tasmoat的的设备同通过ha集成到小爱同学的功能,利用了巴法接入小爱的功能,将本地mqtt转发给巴法以实现小爱控制的功能,前提条件。1需要tasmota 设备, 2.在本地搭建了mqtt服务可, 3.搭建了ha 4.在h…...