news 2026/4/1 23:32:40

jQuery UI 实例 - 转换 Class(Switch Class)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery UI 实例 - 转换 Class(Switch Class)

jQuery UI SwitchClass(转换 Class)特效实例

switchClass()是 jQuery UI Effects 中非常强大的方法,它可以以动画效果从一个 CSS 类平滑转换到另一个 CSS 类。本质上是先移除旧类,再添加新类,整个过程平滑过渡,常用于状态切换、主题更换、模式切换(正常/错误/成功)、动画按钮等场景。

addClass()removeClass()toggleClass()不同的是,switchClass() 明确指定“从 A 切换到 B”,更适合有明确前后状态的交互。

官方文档:https://jqueryui.com/switchClass/

下面提供几个渐进实例,代码使用最新 CDN,可直接复制到 HTML 文件测试。

1.基础转换 Class 动画

从一种状态平滑切换到另一种状态。

<!DOCTYPEhtml><html><head><metacharset="utf-8"><title>jQuery UI SwitchClass 示例</title><linkrel="stylesheet"href="//code.jquery.com/ui/1.13.2/themes/smoothness/jquery-ui.css"><scriptsrc="//code.jquery.com/jquery-3.6.0.min.js"></script><scriptsrc="//code.jquery.com/ui/1.13.2/jquery-ui.min.js"></script><style>.normal{background:#607D8B;color:white;width:200px;height:120px;padding:20px;text-align:center;line-height:120px;border-radius:8px;}.success{background:#4CAF50;color:white;font-size:1.6em;transform:scale(1.1);box-shadow:0 10px 30pxrgba(76,175,80,0.5);border-radius:15px;}.warning{background:#FF9800;color:white;transform:rotate(3deg);box-shadow:0 0 20pxrgba(255,152,0,0.6);}.error{background:#f44336;color:white;transform:scale(0.95)rotate(-2deg);box-shadow:0 0 25pxrgba(244,67,54,0.7);}#box{margin:40px auto;cursor:pointer;}</style></head><body><buttonid="toSuccess">切换到成功状态</button><buttonid="toWarning">切换到警告状态</button><buttonid="toError">切换到错误状态</button><buttonid="toNormal">恢复正常</button><divid="box"class="normal">当前状态:正常</div><script>$(function(){$("#toSuccess").click(function(){$("#box").switchClass("normal","success",1200);});$("#toWarning").click(function(){$("#box").switchClass("normal","warning",1000);});$("#toError").click(function(){$("#box").switchClass("normal","error",1000);});$("#toNormal").click(function(){// 从当前任意状态切换回 normal$("#box").switchClass("success warning error","normal",1500);});});</script></body></html>
2.带缓动 + 回调的转换

使用弹跳缓动,并在转换完成后提示。

<buttonid="modeSwitch">切换模式</button><style>.light{background:#FFFDE7;color:#333;}.dark{background:#212121;color:#FFFDE7;font-weight:bold;}</style><script>$("#modeSwitch").click(function(){$("#box").switchClass("light","dark",1500,"easeInOutBack",function(){alert("已切换到暗黑模式!");}).switchClass("dark","light",1500,"easeInOutBack",function(){alert("已切换回明亮模式!");});// 注意:这里会排队执行,形成来回切换});</script>
3.多状态循环切换

实现三种状态循环:正常 → 警告 → 错误 → 正常。

<buttonid="cycle">循环切换状态</button><script>varstates=["normal","warning","error"];varcurrent=0;$("#cycle").click(function(){varnext=states[(current+1)%states.length];$("#box").switchClass(states[current],next,1000);current=(current+1)%states.length;});</script>
4.常见应用:表单验证状态切换

输入框根据验证结果切换样式。

<inputtype="text"id="username"placeholder="请输入用户名"><buttonid="validate">验证</button><style>.valid{border:3px solid #4CAF50;background:#e8f5e8;}.invalid{border:3px solid #f44336;background:#ffebee;}.default{border:1px solid #ccc;}</style><script>$("#validate").click(function(){varval=$("#username").val();if(val.length>=3){$("#username").switchClass("invalid default","valid",800);}else{$("#username").switchClass("valid default","invalid",800);}});</script>

小技巧

  • 移除旧类、添加新类是原子操作,中间不会出现无样式状态。
  • 支持多个旧类:switchClass("old1 old2", "new", duration)
  • 队列动画:连续调用 switchClass 会自动排队,形成连续状态转换。
  • 与 toggleClass 区别:toggleClass 是“有/无”切换,switchClass 是“从A到B”明确转换。

switchClass() 是实现明确状态迁移的最佳选择,常用于主题切换、模式切换(日间/夜间)、步骤向导状态、按钮多态反馈等。如果你需要暗黑模式全局切换步骤进度条状态动画,或结合 Dialog 的状态反馈示例,请告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/27 17:01:12

终于搞懂了!Attention 机制中的 Q/K/V 到底是什么?

写在前面 作为一名40岁的程序员&#xff0c;我学习大语言模型的过程充满挫折。看了无数篇文章&#xff0c;都在说"Query是查询&#xff0c;Key是键&#xff0c;Value是值"——然后呢&#xff1f;然后就没了。公式倒是列了一大堆&#xff0c;但**为什么要这么设计&…

作者头像 李华
网站建设 2026/4/1 3:22:41

Open-AutoGLM如何实现精准饮食管理?:3大核心技术解析与落地应用

第一章&#xff1a;Open-AutoGLM饮食热量统计概述 Open-AutoGLM 是一个基于生成式语言模型的智能营养分析系统&#xff0c;专注于自动识别食物类型并计算其热量摄入。该系统结合计算机视觉与自然语言处理技术&#xff0c;能够从用户上传的饮食图片或文字描述中提取关键信息&…

作者头像 李华
网站建设 2026/3/30 23:45:07

基于SpringBoot的民宿管理系统

基于 SpringBoot 的民宿管理系统是一个专为民宿行业设计的综合性管理平台&#xff0c;旨在通过 SpringBoot 框架的高效性和灵活性&#xff0c;实现民宿业务的数字化管理&#xff0c;提升运营效率和客户体验。以下是该系统的详细介绍&#xff1a; 系统功能民宿信息管理 2. 支持民…

作者头像 李华
网站建设 2026/3/30 16:24:42

(27)全注解式开发

所谓的全注解开发就是不再使用spring配置文件了。写一个配置类来代替配置文件。 package com.powernode.spring6.config;import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.ComponentScans; import org.springfra…

作者头像 李华
网站建设 2026/3/27 19:48:11

【稀缺资料】Open-AutoGLM定时任务配置秘籍:仅限内部流传的4种高级模式

第一章&#xff1a;Open-AutoGLM定时任务配置概述Open-AutoGLM 是一个面向自动化大语言模型任务调度的开源框架&#xff0c;支持通过声明式配置实现模型推理、数据预处理与结果后处理等任务的周期性执行。其核心功能之一是基于标准时间表达式的定时任务管理&#xff0c;允许用户…

作者头像 李华
网站建设 2026/4/1 17:40:56

拍照即知热量?Open-AutoGLM让你5分钟掌握智能饮食控制术

第一章&#xff1a;拍照即知热量&#xff1f;Open-AutoGLM开启智能饮食新时代在健康管理日益受到重视的今天&#xff0c;饮食控制成为关键一环。Open-AutoGLM 的出现&#xff0c;正在重新定义我们与食物的交互方式——只需对餐盘拍照&#xff0c;系统即可自动识别食材种类、估算…

作者头像 李华