jquery hover 不停闪动问题的解决方法(亦为stop()的使用)
发布时间 - 2026-01-10 22:58:16 点击率:次在前端开发中用的较多的是jquery,之前遇到一个问题,一个下拉的jquery下拉菜单效果,hover上去,一直闪动,用mouseovermouseout好好的,当时没搞定,今天逛论坛看到一个方法,可以行.只怪自己之前看jquery api的时候不是很仔细。

解决闪动 可以使用Stop()
stop([clearQueue],[jumpToEnd])
概述
停止所有在指定元素上正在运行的动画。
如果队列中有等待执行的动画(并且clearQueue没有设为true),他们将被马上执行
参数
[clearQueue],[gotoEnd] Boolean,BooleanV1.2clearQueue:如果设置成true,则清空队列。可以立即结束动画。
gotoEnd: 让当前正在执行的动画立即完成,并且重设show和hide的原始样式,调用回调函数等。
[queue],[clearQueue],[jumpToEnd]BooleanV1.7queue:用来停止动画的队列名称
clearQueue: 如果设置成true,则清空队列。可以立即结束动画。
jumpToEnd: 如果设置成true,则完成队列。可以立即完成动画。
当鼠标移上去的时候就菜单下拉,当鼠标离开的时候菜单上卷,下拉和上卷的动画时间都是5秒种。
$("#menu").hover(
function () {
$("#menu").animate({ height: "500" }, 5000);
},
function () {
$("#menu").animate({ height: "100" }, 5000);
}
);
如果我快速不断地将鼠标移入移出菜单(即,当菜单下拉动画未完成时,鼠标又移出了菜单)就会产生“动画积累”,当鼠标停止移动后,积累的动画还会持续执行,直到动画序列执行完毕。这样导致动画效果与鼠标动作不一致。
要解决此问题只需要在移入移出动画之前加入stop(),结束当前动画进入下个动画即可。
代码如下:
$("#menu").hover(
function () {
$("#menu").stop().animate({ height: "500" }, 5000);
},
function () {
$("#menu").stop().animate({ height: "100" }, 5000);
}
);
如果需到组合动画,在移入移出动画之前加入stop()来停止当前动画,如下
$("#menu").hover(
function () {
$("#menu").stop().animate({ height: "500" }, 5000).animate({ width: "500px" }, 3000);
},
function () {
$("#menu").stop().animate({ height: "100" }, 5000).animate({ width: "100px" },3000);
}
);
效果并不好,因为stop()只是停止了当前第一步的动画(即{height:”500″}),然后又进入了第二步的动画(即[width:”500″})。
此时stop()的第一个参数就派上了用场,它会把下面没有执行的动画序列都清空掉。
$("#menu").hover(
function () {
$("#menu").stop(true).animate({ height: "500" }, 5000).animate({ width: "500px" }, 5000);
},
function () {
$("#menu").stop(true).animate({ height: "100" }, 5000).animate({ width: "100px" },5000);
}
);
当然也可以使用第二个参数,让动画达到最后状态。如:stop(false,true)
以上这篇jquery hover 不停闪动问题的解决方法(亦为stop()的使用)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# jquery
# hover
# 闪烁
# 详解jQuery停止动画——stop()方法的使用
# jQuery stop()用法实例详解
# 逐一介绍Jquery data()、Jquery stop()、jquery delay()函数(详
# jquery中animate的stop()方法作用实例分析
# 理解jQuery stop()方法
# JQuery动画animate的stop方法使用详解
# Jquery ajaxStart()与ajaxStop()方法(实例讲解)
# Jquery阻止事件冒泡 event.stopPropagation
# jq stop()和:is(:animated)的用法及区别(详解)
# 鼠标
# 移出
# 清空
# 设置成
# 给大家
# 当鼠标
# 可以使用
# 的是
# 都是
# 就会
# 第一个
# 上了
# 还会
# 中有
# 只需
# 设为
# 不是很
# 要在
# 希望能
# 第二个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
在Oracle关闭情况下如何修改spfile的参数
iOS发送验证码倒计时应用
Laravel API资源类怎么用_Laravel API Resource数据转换
Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
如何在IIS中新建站点并配置端口与IP地址?
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
Java类加载基本过程详细介绍
JavaScript数据类型有哪些_如何准确判断一个变量的类型
如何快速搭建虚拟主机网站?新手必看指南
WordPress 子目录安装中正确处理脚本路径的完整指南
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
手机软键盘弹出时影响布局的解决方法
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
魔毅自助建站系统:模板定制与SEO优化一键生成指南
Laravel中的Facade(门面)到底是什么原理
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
如何基于云服务器快速搭建个人网站?
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程
Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
简历在线制作网站免费版,如何创建个人简历?
如何快速辨别茅台真假?关键步骤解析
Laravel如何实现文件上传和存储?(本地与S3配置)
BootStrap整体框架之基础布局组件
HTML 中动态设置元素 name 属性的正确语法详解
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
,在苏州找工作,上哪个网站比较好?
js实现获取鼠标当前的位置
如何快速搭建安全的FTP站点?
Laravel如何记录自定义日志?(Log频道配置)
佛山企业网站制作公司有哪些,沟通100网上服务官网?
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
黑客入侵网站服务器的常见手法有哪些?
个人摄影网站制作流程,摄影爱好者都去什么网站?
Laravel如何集成Inertia.js与Vue/React?(安装配置)
Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑
油猴 教程,油猴搜脚本为什么会网页无法显示?
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
如何用IIS7快速搭建并优化网站站点?
晋江文学城电脑版官网 晋江文学城网页版直接进入
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
nodejs redis 发布订阅机制封装实现方法及实例代码

