当前位置: 首页 > news >正文

点击抽奖功能总结

首先用户打开网页,映入眼帘的是一个输入框和一个提交按钮。当用户在输入框中输入自己的年龄并点击提交后,系统会根据输入的年龄给出相应提示。若年龄达到 60 岁,页面将显示一个新的抽奖区域,用户可以点击 “抽奖” 按钮开始抽奖。随着每次点击,抽奖次数会实时更新显示,并且根据抽奖次数的不同,用户将有机会获得不同等级的奖项,从 “恭喜你,没抽到” 到 “隐藏款” 惊喜,充满了未知与期待。

html

<div class="text_box"><input type="text" class="text" /><input type="submit" id="sub" name="sub" onclick="sub_num()" /></div><div class="draw_box"><input type="text" class="draw" readonly /><button onclick="click_draw()">抽奖</button></div>

在这段 HTML 代码中,我们构建了两个主要的区域。text_box类所在的<div>包含一个用于输入年龄的文本框和一个提交按钮,用户在此输入年龄并提交。draw_box类所在的<div>初始时是隐藏的(通过 CSS 的display: none设置),当用户满足特定条件(年龄达到 60 岁)时,该区域将显示出来,其中包含一个只读的文本框用于显示抽奖次数,以及一个 “抽奖” 按钮。

css

	* {margin: 0;padding: 0;}.text_box {width: 30%;margin: 20px 10px 20px 20px;}.draw_box {display: none;margin: 20px 10px 20px 20px;}

CSS 部分,通配符选择器*用于清除所有元素的默认内外边距,保证页面布局的整洁统一。.text_box类设置了宽度以及外边距,定义了输入区域的大小和位置。.draw_box类除了设置外边距外,通过display: none确保抽奖区域初始时不显示在页面上,直到满足条件才通过 JavaScript 动态显示。

js

// 首先获取到第一个提交按钮和第二个的大divlet submit = document.getElementById('sub');let draw = document.getElementsByClassName('draw_box')[0];let draw_num = document.getElementsByClassName('draw')[0];let draw_button = document.getElementsByTagName('button')[0];let submit_box = document.getElementsByClassName('text_box')[0];let click_num = 0;function sub_num() {let num = document.getElementsByClassName('text')[0];console.log(num);if (num.value <= 18) {alert('年龄不够哦');num.value = "";} else if (num.value > 18 && num.value < 35) {alert('青少年');num.value = "";} else if (35 <= num.value && num.value < 60) {alert('加油');num.value = "";} else if (num.value >= 60) {alert('年龄到啦!可以抽奖啦!');draw.style.display = 'block';num.value = "";// submit_box.style.display='none';setTimeout(function() {if (click_num <= 30) {alert('恭喜你,没抽到');draw.style.display = 'none';submit_box.style.display = 'block';alert('要在抽一次吗?');} else if (click_num > 30 && click_num < 60) {alert('太可惜了,二等奖');draw.style.display = 'none';submit_box.style.display = 'block';alert('要在抽一次吗?');} else if (click_num <= 60 && click_num < 120) {alert('恭喜你!一等奖');submit_box.style.display = 'block';draw.style.display = 'none';alert('要在抽一次吗?');} else {alert('隐藏款');submit_box.style.display = 'block';draw.style.display = 'none';alert('要在抽一次吗?');}draw_num.value = "";// click_num = 0;}, 10000)}}function click_draw() {click_num++;draw_num.value = click_num;console.log(click_num);}
  1. 变量初始化:​
  • 首先获取提交按钮元素并赋值给submit变量。​获取抽奖区域的<div>元素并赋值给draw变量。​获取抽奖次数显示的文本框元素并赋值给draw_num变量。​获取 “抽奖” 按钮元素并赋值给draw_button变量。​获取输入年龄的区域<div>元素并赋值给submit_box变量。​
  • 初始化click_num变量为 0,用于记录抽奖次数。​
  1. 提交年龄相关的函数sub_num:​
  • 获取输入年龄的文本框元素num。​
  • 根据输入的年龄进行条件判断:​
  • 若年龄小于等于 18 岁,弹出提示 “年龄不够哦”,并清空输入框内容。​
  • 若年龄大于 18 岁且小于 35 岁,弹出提示 “青少年”,并清空输入框内容。​
  • 若年龄在 35 岁到 60 岁之间,弹出提示 “加油”,并清空输入框内容。​
  • 若年龄大于等于 60 岁,弹出提示 “年龄到啦!可以抽奖啦!”,显示抽奖区域(通过draw.style.display = 'block'),清空输入框内容。同时,设置一个 10 秒的定时器(setTimeout),在 10 秒后根据当前的抽奖次数click_num判断奖项:​
  • 若click_num小于等于 30,弹出提示 “恭喜你,没抽到”,隐藏抽奖区域,显示输入年龄区域,并询问是否再抽一次。​
  • 若click_num大于 30 且小于 60,弹出提示 “太可惜了,二等奖”,隐藏抽奖区域,显示输入年龄区域,并询问是否再抽一次。​
  • 若click_num在 60 到 120 之间,弹出提示 “恭喜你!一等奖”,隐藏抽奖区域,显示输入年龄区域,并询问是否再抽一次。​
  • 若click_num大于 120,弹出提示 “隐藏款”,隐藏抽奖区域,显示输入年龄区域,并询问是否再抽一次。最后清空抽奖次数显示文本框的内容。​
  1. 抽奖函数click_draw:​
  • 每次点击 “抽奖” 按钮,click_num自增 1。​
  • 将更新后的click_num值显示在抽奖次数显示的文本框中(通过draw_num.value = click_num),并在控制台打印click_num值,方便调试。

相关文章:

点击抽奖功能总结

首先用户打开网页&#xff0c;映入眼帘的是一个输入框和一个提交按钮。当用户在输入框中输入自己的年龄并点击提交后&#xff0c;系统会根据输入的年龄给出相应提示。若年龄达到 60 岁&#xff0c;页面将显示一个新的抽奖区域&#xff0c;用户可以点击 “抽奖” 按钮开始抽奖。…...

AWS Bedrock生成视频详解:AI视频创作新时代已来临

💡 TL;DR: AWS Bedrock现已支持AI视频生成功能,让企业无需深厚AI专业知识即可创建高质量视频内容。本文详解Bedrock视频生成能力的工作原理、应用场景和实操指南,助你快速掌握这一革命性技术。 🎬 AWS Bedrock视频生成:改变内容创作的游戏规则 还记得几年前,制作一个专…...

理解 TOGAF®标准中的架构原则

原则是帮助组织实现其使命的基本规则和指南。它们旨在长期稳定且很少修改&#xff0c;在各个领域中充当决策和行动的指南针。在企业架构&#xff08;EA&#xff09;的背景下&#xff0c;原则在指导架构框架的开发和应用方面发挥着至关重要的作用。本文将探讨企业原则和架构原则…...

基于视觉密码的加密二值图像可逆数据隐藏

接下来&#xff0c;分享一篇论文&#xff0c;标题为《Multi-Party Reversible Data Hiding in Ciphertext Binary Images Based on Visual Cryptography》&#xff0c;由Bing Chen等人发表在《IEEE Signal Processing Letters》上。该论文提出了一种基于视觉密码学的多方可逆数…...

ubuntu22.04 中 No module named ‘_bz2‘问题解决方案

前言 本篇是介绍ubuntu22.04中 No module named ‘_bz2‘问题解决方案 网上版本很多&#xff0c;比如安装libbz库什么的&#xff0c;可能别人有用&#xff0c;但是我自己这边出了一堆问题 一、流程 1.1 查看bz2.xx.so文件 看自己的python版本&#xff0c;我新安装了个pyth…...

什么是声波,声波的传播距离受哪些因素影响?

一、声波的定义&#xff1a; 声波是一种机械波&#xff0c;它是通过介质&#xff08;如空气、水、固体等&#xff09;传播的振动。以下是关于声波的详细介绍&#xff1a; 1、声波的产生 声波是由物体的振动产生的。例如&#xff0c;人说话时&#xff0c;声带振动产生声波&…...

用PHPExcel 封装的导出方法,支持导出无限列

用PHPExcel 封装的导出方法&#xff0c;支持导出无限列 避免PHPExcel_Exception Invalid cell coordinate [1 异常错误 /*** EXCEL导出* param [string] $file_name 保存的文件名及表格工作区名&#xff0c;不加excel后缀名* param [array] $fields 二维数组* param [array] $…...

STL-stack栈和queue队列

stack栈和queue队列 在STL中 stack 和 queue 设计为容器适配器,容器适配器是使用特定容器类的封装对象作为其基础容器的类,提供一组特定的成员函数来访问其元素。 在我的STL系列中之前的容器 vector、list、deque 都是从底层类型一步步封装而来的,但是 stack 和 queue 没有…...

AI 提示词不会写?试试 PromptIDE

这段时间&#xff0c;AI 技术大爆炸 已经改变了我们的工作方式&#xff0c;而 会不会用 AI&#xff0c;已经成为区分工作能力的关键&#xff01; &#x1f4a1; 在这个AI重构工作方式的时代&#xff0c;会用和不会用AI的人正在拉开巨大差距&#xff1a; √ 高手用AI——效率飙…...

【python读取并显示遥感影像】

在Python中读取并显示遥感影像&#xff0c;可以使用rasterio库读取影像数据&#xff0c;并结合matplotlib进行可视化。以下是一个完整的示例代码&#xff1a; import rasterio import matplotlib.pyplot as plt import numpy as np# 打开遥感影像文件 with rasterio.open(path…...

代码随想录算法训练营第十三天

LeetCode题目: 110. 平衡二叉树257. 二叉树的所有路径404. 左叶子之和222. 完全二叉树的节点个数3375. 使数组的值全部为 K 的最少操作次数(每日一题) 其他: 今日总结 往期打卡 110. 平衡二叉树 跳转: 110. 平衡二叉树 学习: 代码随想录公开讲解 问题: 给定一个二叉树&#…...

TQTT_KU5P开发板教程---高速收发器之XDMA实现PCIE

文档功能介绍 本文档主要实现了通过一个叫做XDMA的IP&#xff0c;实现PCIE的测试例子。工程新建方法请参考文档《流水灯》。 Vivado创建项目 起始页&#xff08;或 file-->Project-->New 创建新工程(Create New Project) 向导起始页面 点击 Next--> Project Name(…...

蓝桥杯速成刷题清单(上)

一、1.排序 - 蓝桥云课 &#xff08;快速排序&#xff09;算法代码&#xff1a; #include <bits/stdc.h> using namespace std; const int N 5e5 10; int a[N];int main() {int n;cin >> n;for (int i 0; i < n; i) {cin >> a[i];}sort(a, a n);for …...

【FreeRTOS】二值信号量 是 消息队列 吗

在读FreeRTOS内核实现与应用开发实战指南的时候&#xff0c;书中第16章有这么一句话&#xff1a;可以将二值信号量看作只有一个消息的队列&#xff0c;incident这个队列只能为空或满&#xff08;因此称为二值&#xff09;&#xff0c;在运用时只需要之傲队列中是否由消息即可&a…...

BOTA六维力矩传感器在三层AI架构中的集成实践:从数据采集到力控闭环

随着机器人技术的迅猛发展&#xff0c;Bota六维力矩传感器成为三层AI架构中的核心组件。它通过高精度的力与力矩感知能力&#xff0c;为感知层提供实时数据支持&#xff0c;优化了决策层的判断效率&#xff0c;并确保执行层操作的精确性和安全性。 Bota贯通式力矩传感器PixOne&…...

UE5 matcap学习笔记

没难度节点&#xff0c;但是要记住这种思维&#xff0c;移动端常用&#xff1a; 原视频&#xff1a;(美学阿姨)MatCap材质原理讲解与UE5中的实现方法_哔哩哔哩_bilibili...

神经网络 - 关于简单的激活函数的思考总结

最近一直在学习神经网络&#xff0c;有一些收获&#xff0c;也有一些迷惑&#xff0c;所以驻足思考&#xff1a;为什么简单的激活函数如sigmoid函数、ReLU函数&#xff0c;当应用在神经网络的模型中&#xff0c;却可以实现对现实世界复杂的非线性关系的模拟呢&#xff1f;本文我…...

pig 权限管理开源项目学习

pig 源码 https://github.com/pig-mesh/pig 文档在其中&#xff0c;前端在文档中&#xff0c;官方视频教学也在文档中有。 第一次搭建&#xff0c;建议直接去看单体视频&#xff0c;照着做即可。 文章目录 项目结构Maven 多模块项目pig-boot 启动核心模块pig-auth 实现认证和…...

excel中的VBA指令示例(二)

。。。接上篇。 Range("D1").Select ’选择D1单元格 ActiveCell.FormulaR1C1 "装配数量" ‘单元格内容为装配数量 Range("D1").Select Selection.AutoFilter …...

基于vue3与supabase系统认证机制

1. 认证框架概述 系统采用 Supabase 作为认证和数据服务提供商&#xff0c;实现了完整的用户身份验证流程。系统使用基于 JWT (JSON Web Token) 的认证方式&#xff0c;提供了安全可靠的用户身份管理机制。 1.1 技术栈 前端: Vue 3 TypeScript状态管理: Pinia认证服务: Sup…...

【算法笔记】并查集详解

&#x1f680; 并查集&#xff08;Union-Find&#xff09;详解&#xff1a;原理、实现与优化 并查集&#xff08;Union-Find&#xff09;是一种非常高效的数据结构&#xff0c;用于处理动态连通性问题&#xff0c;即判断若干个元素是否属于同一个集合&#xff0c;并支持集合合…...

基于Redis实现短信防轰炸的Java解决方案

基于Redis实现短信防轰炸的Java解决方案 前言 在当今互联网应用中&#xff0c;短信验证码已成为身份验证的重要手段。然而&#xff0c;这也带来了"短信轰炸"的安全风险 - 恶意用户利用程序自动化发送大量短信请求&#xff0c;导致用户被骚扰和企业短信成本激增。本…...

编程中,!! 双感叹号的理解

在编程中&#xff0c;!! 双感叹号的含义取决于上下文。通常情况下&#xff0c;!! 是逻辑非操作符的双重使用&#xff0c;用来将一个值强制转换为布尔类型。 1. 逻辑非操作符 在 JavaScript 中&#xff0c;! 是逻辑非操作符&#xff0c;它会将一个值转换为布尔类型&#xff1a…...

ARM内核与寄存器

ARM内核与寄存器详解 目录 ARM架构概述ARM处理器模式 Cortex-M3内核的处理器模式Cortex-A系列处理器模式 ARM寄存器集 通用寄存器程序计数器(PC)链接寄存器(LR)堆栈指针(SP)状态寄存器(CPSR/SPSR) 协处理器寄存器NEON和VFP寄存器寄存器使用规范常见ARM指令与寄存器操作 ARM架…...

【C++进阶】关联容器:set类型

目录 一、set 基本概念 1.1 定义与特点 1.2 头文件与声明 1.3 核心特性解析 二、set 底层实现 2.1 红黑树简介 2.2 红黑树在 set 中的应用 三、set 常用操作 3.1 插入元素 3.2 删除元素 3.3 查找元素 3.4 遍历元素 3.5 性能特征 四、set 高级应用 4.1 自定义比较…...

Linux内核——X86分页机制

X86分页机制 x86的分页单元支持两种分页模式&#xff1a;常规分页与扩展分页。 常规分页采用两级结构&#xff0c;固定页大小为4KB。线性地址被划分为三个字段&#xff1a; 页目录索引&#xff08;最高10位&#xff09;页表索引&#xff08;中间10位&#xff09;页内偏移&am…...

重温Java - Java基础二

工作中常见的6中OOM 问题 堆内存OOM 堆内存OOM 是最常见的OOM了。出现堆内存OOM 问题的异常信息如下 java.lang.OutOfMemoryError: Java heap space此OOM是由于Java中的heap的最大值&#xff0c;已经不能满足需求了。 举个例子 Test public void test01(){List<OOMTest…...

回溯算法+对称剪枝——从八皇后问题到数独问题(二)

引入&#xff1a; 本节我们进一步完善八皇后问题&#xff0c;学习剪枝、八皇后残局问题 进一步领会逻辑编程的概念&#xff0c;深入体会回溯算法&#xff0c;回顾上一节提到的启发搜索策略。 回顾&#xff1a; 八皇后问题&#xff1a;我们需要在一个空棋盘上放置 n 个皇后&a…...

基于 Spring Boot 瑞吉外卖系统开发(三)

基于 Spring Boot 瑞吉外卖系统开发&#xff08;三&#xff09; 分类列表 静态页面 实现功能所需要的接口 定义Mapper接口 Mapper public interface CategoryMapper extends BaseMapper<Category> {}定义Service接口 public interface CategoryService extends ISe…...

Pascal VOC 2012 数据集格式与文件结构

Pascal VOC 2012 1 Pascal VOC 2012 数据集1.1 数据集概述1.2 文件结构1.3 关键文件和内容格式(1) Annotations/ 目录(2) ImageSets/ 目录(3) JPEGImages/ 目录(4) SegmentationClass/ 和 SegmentationObject/ 目录 1.4 标注格式说明(1) 目标检测标注(2) 语义分割标注(3)实例分…...

11:00开始面试,11:08就出来了,问的问题有点变态。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到8月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%…...

MySQL与Oracle字段类型对比及迁移指南

文章目录 MySQL与Oracle字段类型对比及迁移指南1. 核心字段类型对照表2. 常见函数对照表2.1 字符串函数2.2 日期函数2.3 数值函数2.4 类型转换函数2.5 空值处理函数2.6 其他常用函数3. 迁移配置细则4. 迁移工具推荐5. 常见问题解决方案6. 性能优化建议MySQL与Oracle字段类型对比…...

Spring MVC 处理 HTTP 状态码、响应头和异常的完整示例

Spring MVC 处理 HTTP 状态码、响应头和异常的完整示例 1. 正常响应处理 通过 ResponseEntity 可以灵活控制 HTTP 状态码、响应头和响应体。 代码示例&#xff1a;创建资源返回 201 并设置 Location 头 import org.springframework.http.HttpHeaders; import org.springfram…...

http页面的加载过程

HTTP/2 核心概念 1.1 流&#xff08;Stream&#xff09; • 定义&#xff1a;HTTP/2 连接中的逻辑通道&#xff0c;用于传输数据&#xff0c;每个流有唯一标识符&#xff08;Stream ID&#xff09;。 • 特点&#xff1a; ◦ 支持多路复用&#xff08;多个流并行传输&#…...

动手人形机器人(RL)

1 PPO的讲解 核心步骤&#xff0c;如策略网络和价值网络的定义、优势估计、策略更新、价值更新等基础功能的实现 2 代码构成 可能涉及 初始化&#xff0c;Behavior Clone 3 动手强化学习 import pytorch as torch class actorcritic ##等待补充 4 PD Gains 在机器人学中&…...

使用RabbitMQ实现异步秒杀

搭建RabbitMQ 在虚拟机上用docker搭建RabbitMQ&#xff0c;首先拉取镜像 docker run --privilegedtrue -d -p 5672:5672 -p 15672:15672 --name rabbitmq rabbitmq:management mkdir -p /usr/local/docker/rabbitmq再创建rabbitmq容器&#xff0c;下面的命令已经能够创建之后…...

基于PyQt5的企业级生日提醒系统设计与实现

在企业人力资源管理场景中,员工生日提醒是一项重要的关怀功能。本文将以一个基于PyQt5开发的生日提醒系统为例,深入解析桌面应用程序开发中的关键技术实现,涵盖GUI设计、数据持久化、系统集成、动画效果等核心模块。 一、技术选型分析 1.1 PyQt5框架优势 跨平台特性:支持W…...

蓝桥杯嵌入式第16届——ADC模数转化部分

将外部的模拟信号转换为数字信号 &#xff08; ADC可以将引脚上连续变化的模拟电压转换为内存中存储的数字变量&#xff0c;建立模拟电路到数字电路的桥梁 &#xff09; STM32 - ADC 笔记_stm32 adc电容-CSDN博客 引脚状况 STM32cubemx配置 ADC1配置 ADC2配置 代码部分 …...

拜特科技签约天津城投集团,携手共建司库管理系统

近日&#xff0c;拜特科技成功签约天津城市基础设施建设投资集团有限公司&#xff08;以下简称“天津城投集团”&#xff09;&#xff0c;携手共建司库管理系统。 自2015年结缘以来&#xff0c;拜特科技与天津城投集团已携手并进十年&#xff0c;构建了稳固且高效的合作桥梁。…...

Spring Boot 中集成 Knife4j:解决文件上传不显示文件域的问题

Spring Boot 中集成 Knife4j&#xff1a;解决文件上传不显示文件域的问题 在使用 Knife4j 为 Spring Boot 项目生成 API 文档时&#xff0c;开发者可能会遇到文件上传功能不显示文件域的问题。本文将详细介绍如何解决这一问题&#xff0c;并提供完整的解决方案。 Knife4j官网…...

Nuxt.js的useHead有哪些对象

在Nuxt.js框架中&#xff0c;useHead是一个用于操作页面<head>部分的辅助函数。它返回一个包含多个对象的集合&#xff0c;允许你轻松地在组件中修改或添加 HTML 的<head>内容。 具体来说&#xff0c;useHead 返回的对象集合包括&#xff1a; title: 用于设置页面…...

JavaScript的可选链操作符 ?.

JavaScript的可选链操作符&#xff08;Optional Chaining Operator&#xff09;是 ES2020&#xff08;ES11&#xff09; 引入的新特性&#xff0c;通过语法 ?. 简化对深层嵌套对象属性、方法或数组元素的访问&#xff0c;避免因中间值为 null 或 undefined 而引发的错误。 核…...

增长黑客:激活实验助力增长

激活实验是推动用户增长的重要手段。下面为大家详细介绍激活实验的关键步骤与重点解决问题 激活实验的三个关键步骤 1. 明晰 “啊哈时刻” 路径 “啊哈时刻” 指用户瞬间领悟产品价值的瞬间。要达成这一点&#xff0c;需明确用户体验到 “啊哈时刻” 的所有路径。以在线绘图工具…...

STM32低功耗

设置不同位来配置是哪种低功耗模式 WAKEUP引脚可以唤醒任何睡眠状态,但是只有待机模式是属于WAKEUP唤醒&#xff0c;其他模式都是属于中断唤醒&#xff0c;所以待机模式要使能EWUP引脚&#xff0c;还要手动清除唤醒标志位&#xff08;在进入待机模式前就要清除标志位&#xff…...

【精品PPT】2025固态电池知识体系及最佳实践PPT合集(36份).zip

精品推荐&#xff0c;2025固态电池知识体系及最佳实践PPT合集&#xff0c;共36份。供大家学习参考。 1、中科院化学所郭玉国研究员&#xff1a;固态金属锂电池及其关键材料.pdf 2、中科院物理所-李泓固态电池.pdf 3、全固态电池技术研究进展.pdf 4、全固态电池生产工艺.pdf 5、…...

头歌数据库【数据库概论】第10-11章 故障恢复与并发控制

第1关&#xff1a;数据库恢复技术 1、事务的&#xff08; A&#xff09;特性要求事务必须被视为一个不可分割的最小工作单元 A、原子性 B、一致性 C、隔离性 D、持久性 2、事务的&#xff08;C &#xff09;特性要求一个事务在执行时&#xff0c;不会受到其他事务的影响。 A、原…...

qt之opengl使用

使用qt中的openglWidget绘制一个三角形。自定义的类继承关系sunOpengl : public QOpenGLWidget,QOpenGLFunctions_3_3_Core 代码如下 /*----MainWindow.cpp----------------------------------------------*/ #include "mainwindow.h" #include "./ui_mainwin…...

Spark Core编程

一 Spark 运行架构 1 运行架构 定义 Spark 框架的核心是一个计算引擎&#xff0c;整体来说&#xff0c;它采用了标准 master-slave 的结构 如图所示 2 核心组件 Spark 框架有两个核心组件: 1)Driver 2)Spark 驱动器节点&#xff08;用于执行 Spark 任务中的 main 方法&…...

蓝桥杯 B3619 10 进制转 x 进制

题目描述 给定一个十进制整数 n 和一个小整数 x。将整数 n 转为 x 进制。对于超过十进制的数码&#xff0c;用 A&#xff0c;B ... 表示。 输入格式 第一行一个整数 n&#xff1b; 第二行一个整数 x。 输出格式 输出仅包含一个整数&#xff0c;表示答案。 输入输出样例 …...

spring mvc中不同服务调用类型(声明式(Feign)、基于模板(RestTemplate)、基于 SDK、消息队列、gRPC)对比详解

RestControllerAdvice 和 ControllerAdvice 对比详解 1. 基本概念 注解等效组合核心作用ControllerAdviceComponent RequestMapping&#xff08;隐式&#xff09;定义全局控制器增强类&#xff0c;处理跨控制器的异常、数据绑定或全局响应逻辑。RestControllerAdviceControll…...