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

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 的状态反馈示例,请告诉我!

http://www.cnnetsun.cn/news/166290.html

相关文章:

  • jQuery UI 实例 - 定位(Position)
  • 自走式除草机器人结构设计
  • Open-AutoGLM体温监测实战指南(从部署到数据分析全流程曝光)
  • Open-AutoGLM如何实现个性化体重预测:3个你必须掌握的技术细节
  • 【家庭自动化终极方案】:用Open-AutoGLM实现零遗忘家务安排
  • GraphRAG实战终极指南!从0到1打通OpenAI+LangChain+Neo4j,收藏这篇就够了!
  • 最近在研究石墨烯材料,这玩意儿真是神奇。说它是“材料界的明星”一点也不夸张。石墨烯的导电性和导热性都超强,而且它只有一层碳原子厚,简直是纳米技术的完美代表
  • Open-AutoGLM如何重构洗衣流程:9大优化策略全公开
  • 【AI营养师来了】:Open-AutoGLM饮食热量统计系统深度测评与优化建议
  • 基于单片机的智能门禁系统的设计与实现
  • 基于PLC工业机器人视觉定位及自动码垛系统的设计
  • 基于SSM的大王门店管理系统设计与实现
  • 网络安全完全指南:从小白到高手的系统学习路线与实战精讲
  • C++ 最強武器:利用類型系統實現零成本抽象
  • (28)全注解开发底层原理
  • jQuery UI 实例 - 对话框(Dialog)
  • 模型版本迭代中的回归测试策略
  • 【Open-AutoGLM家务提醒安排】:揭秘智能家庭任务调度背后的AI黑科技
  • Open-AutoGLM食材购买避坑指南:90%人忽略的3类关键营养匹配原则
  • Open-AutoGLM任务中断恢复实战(断点续训技术大揭秘)
  • 【Open-AutoGLM饮食热量统计】:揭秘AI自动识别食物热量的黑科技与实测效果
  • Linly-Talker如何避免‘恐怖谷效应’?外观设计心理学研究
  • 基于Spring Boot的儿童福利院管理系统的设计与实现毕业设计
  • 基于Android的网上点餐APP
  • 如何用Open-AutoGLM实现秒级故障响应?一线架构师亲授压箱底方案
  • Open-AutoGLM日志系统揭秘,掌握这6个参数才算真正入门
  • jQuery UI 实例 - 放置(Droppable)
  • 探索三相两电平光伏逆变器DC - AC部分的Simulink仿真之旅
  • 【AI推理服务稳定性提升】:基于Open-AutoGLM的后台运行配置最佳实践
  • Open-AutoGLM网络配置避坑指南(一线专家亲授12年实战经验)