news 2026/4/3 5:12:19

jQuery UI 实例 - 切换 Class(Toggle Class)

作者头像

张小明

前端开发工程师

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

jQuery UI ToggleClass(切换 Class)特效实例

toggleClass()是 jQuery UI Effects 中非常实用的方法,它可以以动画效果在添加和移除 CSS 类之间切换。如果元素已有该类,则平滑移除;如果没有,则平滑添加。常用于按钮激活状态、选中高亮、折叠面板开关、主题切换、表单字段焦点等交互反馈。

它支持持续时间、easing 缓动函数和回调函数,比普通.toggleClass()更富有动态感。

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

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

1.基础切换 Class 动画

点击元素自身切换状态。

<!DOCTYPEhtml><html><head><metacharset="utf-8"><title>jQuery UI ToggleClass 示例</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>.active{background:#2196F3;color:white;font-size:1.6em;padding:30px;border-radius:12px;box-shadow:0 10px 25pxrgba(33,150,243,0.4);transform:scale(1.1)rotate(2deg);}#box{width:200px;height:120px;background:#795548;color:white;text-align:center;line-height:120px;margin:40px auto;cursor:pointer;border-radius:8px;}</style></head><body><divid="box">点击我切换状态</div><script>$(function(){$("#box").click(function(){$(this).toggleClass("active",1000);// 1秒内切换类});});</script></body></html>
2.按钮控制切换 + 缓动效果

使用独立按钮控制,并添加弹跳缓动。

<buttonid="toggleBtn">切换状态</button><style>.success{background:#4CAF50;color:white;transform:scale(1.15);box-shadow:0 0 30pxrgba(76,175,80,0.6);}</style><script>$("#toggleBtn").click(function(){$("#box").toggleClass("success",1200,"easeOutBounce");});</script>
3.多个类同时切换 + 回调

切换多个类,并在动画结束后提示。

<style>.selected{background:#FF9800;font-weight:bold;}.enlarged{font-size:2em;transform:rotate(-5deg);}</style><buttonid="multiToggle">切换选中+放大</button><script>$("#multiToggle").click(function(){$("#box").toggleClass("selected enlarged",1500,function(){varhasClass=$(this).hasClass("selected");alert(hasClass?"已激活多重状态!":"已恢复默认");});});</script>
4.常见应用:折叠面板开关按钮

结合图标,实现“展开/收起”按钮效果。

<buttonid="collapseBtn"class="ui-button"><spanclass="ui-icon ui-icon-triangle-1-s"></span>展开详情</button><divid="content"style="display:none;padding:20px;background:#eee;">这里是隐藏的详细内容...</div><style>.open{transform:rotate(180deg);}</style><script>$("#collapseBtn").click(function(){$("#content").slideToggle(800);// 内容滑动显示/隐藏$(this).toggleClass("open",600);// 箭头旋转动画$(this).find("span").toggleClass("ui-icon-triangle-1-s ui-icon-triangle-1-n",600);$(this).text(function(i,text){returntext.includes("展开")?"收起详情":"展开详情";});});</script>

小技巧

  • 可动画属性:所有数值型 CSS(如 color、background、width、font-size、opacity、transform、box-shadow 等)都会平滑过渡。
  • 队列动画:连续多次 toggleClass 会自动排队,形成连续效果。
  • 与其他 Effects 结合:如先.effect("shake")再 toggleClass 实现错误提示。
  • 性能:避免在大量元素上同时使用复杂动画。

toggleClass() 是实现交互状态切换的最佳方式之一,常用于导航高亮、列表选中、模式切换(暗黑/明亮主题)等。如果你需要暗黑模式切换列表多选高亮、或表单字段错误/正确状态动画的完整示例,请告诉我!

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

白话AI Agent (1): 构建一个系统性AI到底需要哪些能力?

接下来要开启白话AI-Agent系列。确实有一段时间没有写文章了&#xff0c;是因为一直在进行企业AI Agent的实战项目中&#xff0c;一直在进行过程中的思考与总结&#xff0c;一直没有将其编织成一张体系化的网格。但现在&#xff0c;经历了一段时间的沉淀之后让我对于AI的整体架…

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

从零构建AI菜谱引擎:Open-AutoGLM实战指南(仅限专业开发者)

第一章&#xff1a;Open-AutoGLM 菜谱自动搜索系统概述Open-AutoGLM 是一个基于生成语言模型&#xff08;GLM&#xff09;的智能菜谱自动搜索系统&#xff0c;旨在通过自然语言理解与语义检索技术&#xff0c;为用户提供精准、个性化的烹饪方案推荐。系统融合了多模态输入解析、…

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

基于Java的乐器类课程报名预约系统

SpringBoot基于Java的乐器类课程报名预约系统介绍 一、系统定位与核心目标 该系统是一款专为音乐培训机构、艺术学校或独立音乐教师设计的在线课程管理与预约平台&#xff0c;旨在解决传统乐器课程报名中的信息分散、预约冲突、沟通低效等问题。系统通过数字化手段整合课程信息…

作者头像 李华
网站建设 2026/4/1 7:38:26

C++類型系統進化:從C++98到C++23的效能與安全性革命

C類型系統進化&#xff1a;從C98到C23的效能與安全性革命類型系統是C的核心&#xff0c;其進化直接影響程式碼的效能、安全性和表達力。讓我們看看從C98到C23的類型系統如何實現你提到的驚人提升。C98/03&#xff1a;基礎但有限制的類型系統在C98中&#xff0c;類型系統相對簡單…

作者头像 李华
网站建设 2026/3/2 14:23:00

【Open-AutoGLM性能调优实战】:从0到每秒万级数据点的处理突破

第一章&#xff1a;Open-AutoGLM性能调优的背景与意义在大规模语言模型应用日益普及的背景下&#xff0c;Open-AutoGLM作为一款开源的自动推理生成语言模型&#xff0c;其运行效率直接影响到实际场景中的响应速度与资源消耗。随着模型参数量的增长&#xff0c;推理延迟和内存占…

作者头像 李华