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 发布订阅机制封装实现方法及实例代码