news 2025/12/27 17:34:29

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/22 23:50:43

jQuery UI 实例 - 颜色动画(Color Animation)

jQuery UI 颜色动画&#xff08;Color Animation&#xff09;实例 jQuery UI 自带颜色动画支持&#xff0c;无需额外插件。你可以使用 .animate() 方法平滑过渡颜色属性&#xff08;如 backgroundColor、color、borderColor 等&#xff09;&#xff0c;常用于高亮提示、状态反…

作者头像 李华
网站建设 2025/12/22 19:48:15

jQuery UI 实例 - 部件库(Widget Factory)

jQuery UI Widget Factory&#xff08;部件工厂&#xff09;实例 Widget Factory 是 jQuery UI 的核心机制&#xff08;$.widget()&#xff09;&#xff0c;它允许你以标准、模块化的方式创建可重用、可配置、可扩展的状态ful 插件&#xff08;部件&#xff09;。所有 jQuery …

作者头像 李华
网站建设 2025/12/23 1:30:39

为什么高端家庭都在用Open-AutoGLM做任务管理?真相令人震惊

第一章&#xff1a;为什么高端家庭都在用Open-AutoGLM做任务管理&#xff1f;真相令人震惊在智能家居与家庭自动化深度融合的今天&#xff0c;越来越多高净值家庭选择 Open-AutoGLM 作为核心任务调度引擎。它不仅具备自然语言理解能力&#xff0c;还能通过多模态感知动态调整家…

作者头像 李华
网站建设 2025/12/26 15:29:39

指路突破主图之选股指标公式

{}ABC1:REF(H,1)/MAX(REF(C,1),REF(O,1))>1.03 AND MAX(REF(C,1),REF(O,1))/MIN(REF(C,1),REF(O,1))< 1.02; ABC2:C/REF(C,1)>1.09 AND REF(V,1)>REF(V,2) AND REF(V,1)>REF(MA(V,5),1); ABC3:REF(O,1)< REF(H,2) AND C>O; 集合1:ABC1 AND ABC2 AND ABC3;…

作者头像 李华
网站建设 2025/12/24 1:37:20

基于单片机热敏电阻PT100温度控制系统设计

摘 要 温度计量是计量学的一个重要分支&#xff0c;它在国民经济各领域中占有重要的地位。人们的日常生活、工农业生产和科学实验等许多方面都与温度测量有着十分密切的关系。 本文在查阅、分析了现有的几种不同的测温原理&#xff0c;分析确定了热敏电阻测温&#xff0c;并对…

作者头像 李华
网站建设 2025/12/26 14:37:28

(29)阶段性个人总结

至此我们已经学完spring中最大两个的特性之一IoC 为什么要有Ioc&#xff1f; 在传统的项目中我们发现我们的程序通过new的方式来创建对象的时候&#xff0c;耦合度较高&#xff0c;下层改变了什么&#xff08;比如说换了个数据库&#xff09;&#xff0c;上层的代码就要跟着改变…

作者头像 李华