高效实现多个DIV悬停提示:jQuery与纯CSS解决方案

高效实现多个DIV悬停提示:jQuery与纯CSS解决方案

本文旨在解决在多个div元素上实现悬停提示时,背景高亮效果错误地应用于所有元素的问题。文章提供了两种解决方案:首先,利用jquery的`this`关键字和`find()`方法精确控制单个元素的样式;其次,推荐使用更高效、性能更好的纯css `:hover`选择器来达到相同效果。文中附带代码示例、html结构优化建议,并对比了两种方法的优劣,以指导开发者选择最佳实践。

问题分析:多DIV悬停提示的样式冲突

在网页开发中,当存在多个相似的交互元素(例如多个带有悬停提示的div)时,我们常常希望鼠标悬停在其中一个元素上时,只有该元素及其相关子元素发生样式变化,而不是影响到所有同类元素。原始代码中,jQuery事件处理函数内的选择器$(“.tooltip-img”)会选择页面上所有带有tooltip-img类的元素。这意味着无论鼠标悬停在哪一个.tooltip元素上,所有.tooltip-img元素的背景都会被高亮,导致了不期望的全局效果。

原始jQuery代码片段:

$(document).ready(function() {  $(".tooltip").on('mouseover', function() {    $(".tooltip-img").addClass("tooltip-img-img") // 问题所在:全局选择  });  $(".tooltip").on('mouseleave', function() {    $(".tooltip-img").removeClass("tooltip-img-img") // 问题所在:全局选择  });});

原始HTML结构示例:

值得注意的是,原始HTML中

解决方案一:使用jQuery精确控制悬停元素

为了解决全局高亮问题,我们需要在事件处理函数中,将样式修改操作限定在当前触发事件的元素及其后代元素上。这可以通过jQuery的this关键字和find()方法实现。

核心概念:this与find()

this关键字:在jQuery事件处理函数内部,this指向触发该事件的DOM元素。将其包装成jQuery对象$(this),可以方便地使用jQuery提供的方法。find()方法:$(selector).find(filter)方法用于在当前匹配元素集合的每个元素的后代中,查找符合filter选择器的元素。通过结合$(this)和find(),我们可以确保只对当前悬停元素内部的特定子元素进行操作。

代码实现

将原始jQuery代码中的全局选择器$(“.tooltip-img”)替换为$(this).find(“.tooltip-img”)。

$(document).ready(function() {  // 鼠标悬停事件  $(".tooltip").on('mouseover', function() {    // 使用 $(this) 引用当前悬停的 .tooltip 元素    // 然后使用 .find() 查找其内部的 .tooltip-img 元素    $(this).find(".tooltip-img").addClass("tooltip-img-img");  });  // 鼠标离开事件  $(".tooltip").on('mouseleave', function() {    $(this).find(".tooltip-img").removeClass("tooltip-img-img");  });});

HTML结构修正

考虑到HTML语义化和有效性,建议移除

CSS样式

以下是相关CSS样式,用于定义.tooltip-img的初始状态和.tooltip-img-img的悬停状态。

.tooltip-img {  float: right;  position: relative;  top: 83px;  left: 214px;  background: transparent;  border: none;  width: 25px;  height: 25px;}.tooltip-img-img {  width: 25px !important;  height: 25px !important;  border-radius: 15px;  background: #0f0 !important;}/* 其他 tooltip 相关的 CSS 保持不变 */.tooltip {  position: relative;}.tooltip:hover .tooltiptext {  display: block;}.tooltip:before,.tooltip:after {  display: block;  opacity: 0;  pointer-events: none;  position: absolute;}.tooltip:after {  height: 0;  top: 20px;  left: 100px;  width: 0;}.tooltip:before {  padding: 4px 8px;  width: 106px;  height: 22px;  background: red;  font-size: 14px;  color: #ffffff;  content: attr(data-title);  top: 75px;  white-space: nowrap;  left: 90px;  text-align: center;}.tooltip.text:after,.tooltip.text:before {  transform: translate3d(0, -10px, 0);  transition: all 0.15s ease-in-out;}.tooltip.text:hover:after,.tooltip.text:hover:before {  opacity: 1;  transform: translate3d(0, 0, 0);}.div-style {  border: 1px solid red;  width: 250px;  height: 120px;  display: flex;  float: left;  margin-left: 50px;}

解决方案二:推荐使用纯CSS :hover实现

对于简单的悬停样式变化,纯CSS通常是更优的选择。它具有更好的性能、更广泛的浏览器支持,并且代码更加简洁易懂,无需JavaScript即可实现。

核心概念:CSS :hover伪类与后代选择器

CSS的:hover伪类可以应用于任何元素,当鼠标指针悬停在该元素上时,其定义的样式就会生效。结合后代选择器,我们可以轻松地实现当父元素(例如.tooltip)被悬停时,其特定子元素(例如.tooltip-img)的样式变化。

代码实现

通过修改CSS,将原本由JavaScript添加的.tooltip-img-img类的样式直接定义在.tooltip:hover .tooltip-img选择器下。这样,当鼠标悬停在.tooltip元素上时,其内部的.tooltip-img元素就会自动应用这些样式。

.tooltip-img {  float: right;  position: relative;  top: 83px;  left: 214px;  background: transparent;  border: none;  width: 25px;  height: 25px;}/* 移除 .tooltip-img-img 类定义,将其合并到 :hover 规则中 *//* .tooltip-img-img { ... } *//* 当 .tooltip 元素被悬停时,其内部的 .tooltip-img 元素应用以下样式 */.tooltip:hover .tooltip-img {  width: 25px !important;  height: 25px !important;  border-radius: 15px;  background: #0f0 !important;}/* 其他 tooltip 相关的 CSS 保持不变 */.tooltip {  position: relative;}.tooltip:hover .tooltiptext {  display: block;}.tooltip:before,.tooltip:after {  display: block;  opacity: 0;  pointer-events: none;  position: absolute;}.tooltip:after {  height: 0;  top: 20px;  left: 100px;  width: 0;}.tooltip:before {  padding: 4px 8px;  width: 106px;  height: 22px;  background: red;  font-size: 14px;  color: #ffffff;  content: attr(data-title);  top: 75px;  white-space: nowrap;  left: 90px;  text-align: center;}.tooltip.text:after,.tooltip.text:before {  transform: translate3d(0, -10px, 0);  transition: all 0.15s ease-in-out;}.tooltip.text:hover:after,.tooltip.text:hover:before {  opacity: 1;  transform: translate3d(0, 0, 0);}.div-style {  border: 1px solid red;  width: 250px;  height: 120px;  display: flex;  float: left;  margin-left: 50px;}

HTML结构

HTML结构与jQuery方案中的修正版本保持一致,无需JavaScript文件,但为了保持完整性,可以保留jQuery CDN链接,或直接删除。

总结与最佳实践

本文提供了两种解决多DIV悬停提示样式冲突的方法:

jQuery方案:通过$(this).find()精确选择当前悬停元素的子元素进行样式修改。这种方法适用于需要复杂逻辑判断或动态数据交互的场景。纯CSS :hover方案:利用CSS的:hover伪类和后代选择器直接在样式表中定义悬停效果。这是更推荐的方法,因为它:性能更优:浏览器在渲染CSS时效率更高,无需JavaScript引擎介入。代码简洁:减少了JavaScript代码量,使维护更加容易。兼容性好::hover是标准的CSS特性,在所有现代浏览器中都得到良好支持。

最佳实践建议:对于简单的UI状态变化(如悬停时的背景、边框、文本颜色等),应优先考虑使用纯CSS实现。只有当交互逻辑涉及更复杂的条件判断、动画控制或与后端数据交互时,才考虑引入JavaScript(如jQuery)。此外,始终注意编写语义化和有效的HTML结构,避免嵌套无效元素,以确保网页的可访问性和兼容性。

以上就是高效实现多个DIV悬停提示:jQuery与纯CSS解决方案的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1591088.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 06:31:10
下一篇 2025年12月23日 06:31:26

相关推荐

  • CSS如何实现饼状的Loading等待图的效果(图)

    这篇文章主要介绍了用纯css实现饼状loading等待图效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 写在前面 之前碰到一个小练习,就是用纯CSS3来写饼状的loading效果,之前着实没有写过这玩意儿,小花完全没头绪,然后参考了张鑫旭老师的CSS3实现鸡蛋饼饼状图loading等待转转转…

    2025年12月23日 好文分享
    000
  • 详细介绍使用纯CSS实现自适应正方形的案例

    在处理移动端页面时,我们有时会需要将 banner 图做成与屏幕等宽的正方形以获得最佳的体验效果,如 flipbord 的移动页面: 那么应该怎么使用纯 CSS 制作出能够自适应大小的正方形呢? 方案一:CSS3 vw 单位 CSS3 中新增了一组相对于可视区域百分比的长度单位 vw, vh, vm…

    2025年12月23日 好文分享
    000
  • 使用CSS自定义radio、checkbox样式的示例详解

    以前做自定义样式的radio, checkbox 的时候,一直是如下结构 文字 然后定义diyRadio 的样式作为新Radio, 再用js 做关联。 知道今天才知道可以用标签的for 属性 + :checked 做,纯CSS( 真是太不应该了,学东西还是要认真、细致点。 ) DIY 单选项示例如下…

    好文分享 2025年12月23日
    000
  • CSS3+jQuery实现环形进度条的详解

    整体思路是:通过裁切(clip)产生两个半圆展示出静态的进度条,而后通过旋转(rotate)角度的变化产生动态效果。 先来回顾两个基础知识点 (1)css的一个不常见的属性: clip: rect(top, right, bottom, left); 这个属性规定了一个裁切的矩形,其中top和bot…

    2025年12月23日 好文分享
    000
  • CSS实现Footer置底的五种方式的分享

    页脚置底(sticky footer)就是让网页的footer部分始终在浏览器窗口的底部。 当网页内容足够长以至超出浏览器可视高度时,页脚会随着内容被推到网页底部;但如果网页内容不够长,置底的页脚就会保持在浏览器窗口底部。 方法一:将内容部分的margin-bottom设为负数 footer htm…

    2025年12月23日
    000
  • 整合20个CSS/CSS3常用属性

    这里我总结了一下平时自己在项目中经常用到的20个css常用的样式,都是些个人的经验,这里分享给大家,希望对大家有所帮助 1.强制文本单行显示:white-space:nowrap; 2.设置溢出文本显示为省略标记:text-overflow:ellipsis;(注:text-overflow:cli…

    好文分享 2025年12月23日
    000
  • 关于CSS3中选择符的实例详解

    英文原文: www.456bereastreet.com/archive/200601/css_3_selectors_explained/中文翻译: www.dudo.org/article.asp?id=197注:本文写于2006年1月,当时IE7、IE8和Firefox3还未发行,文中所有说的…

    好文分享 2025年12月23日
    000
  • 阐述什么是CSS3?

    网页制作Webjx文章简介:CSS3不是新事物,更不是只是围绕border-radius属性实现的圆角。它正耐心的坐在那里,已经准备好了首次登场,呷着咖啡,等着浏览器来铺上红地毯。            CSS3不是新事物,更不是只是围绕border-radius属性实现              …

    好文分享 2025年12月23日
    000
  • 用css实现文本超链文字右边加一个箭头图标

    许多知名网站都在文字链的右边加一个箭头图标,例如google站长管理后台,alexa官网等,这样设计的好处是让链接更醒目,更容易辨认。 文字链右边加一个箭头图标的方法,多数人是使用css背景图来实现,包括上面提到的Google站长管理后台,Alexa官网等。是的,这种方法最容易掌握和应用。这正是本文…

    2025年12月23日
    000
  • 用CSS实现背景图片透明而文字不透明的两种方法

    这篇文章主要介绍了css实现背景图片透明而文字不透明效果的两种方法,需要的朋友可以参考下 摘要: 方法一(毛玻璃效果):背景图 + 伪类 + flite:blur(3px) 方法二(半透明效果):背景图 + 定位 + background:rgba(255,255,255,0.3) CSS实现背景图…

    2025年12月23日
    000
  • css实现元素水平垂直居中常见的两种方式实例详解

    这篇文章主要给大家介绍了css实现元素水平垂直居中的两种方式,文中给出了完整的示例代码供大家参考学习,对大家的学习或者工作具有一定的参考价值,有需要的朋友们下面来一起看看吧。 一、父元素的flex布局实现元素的水平垂直居中 示例代码如下: Document .parent{ display:flex…

    2025年12月23日
    000
  • 总结加载css中link与@import的几点区别

    加载css的两种方式: @import 方式 @import url(“b.css”); 对比解释 设置样式的方式:行内样式、内联样式、外联样式、导入样式 当@import与内联样式一起时,内联样式>导入样式 立即学习“前端免费学习笔记(深入)”; 除了上述情况,其它时候以样式加载顺序为参考,…

    好文分享 2025年12月23日
    000
  • 必须了解的css中出现的bug以及修复方法

    与许多编程语言相比,css是一种相当容易学习的语言。它的语法简单明了,而且由于它的表现本质,开发人员并不需要处理复杂的逻辑。但是,当在不同的浏览器中测试代码时,困难就会随之出现。浏览器bug何不一至的显示方式是大多css开发人员面临的主要难题。你的设计在一种浏览器上显示的很好,但在另一种浏览器上布局…

    好文分享 2025年12月23日
    000
  • 什么是css sprite?对css sprite技巧总结

    css  sprite做为一个前端人员来说必须要掌握,但是这个对于刚学习的同学来说是由困难的,下面我就专门为这个内容做一次分享,这里没有网络图片地址,若内容显示不全面你可以到我的个人博客中去查看 CSS Sprites在国内很多人叫css精灵,是一种网页图片应用处理方式。它允许你将一个页面涉及到的所…

    2025年12月23日
    000
  • CSS中margin边界叠加问题的解决方法介绍(图文)

    本文主要介绍了css中margin边界叠加问题及解决方案。具有很好的参考价值。下面跟着小编一起来看下吧 CSS的margin边界叠加深度剖析 边界叠加简介 边界叠加是一个相当简单的概念。但是,在实践中对网页进行布局时,它会造成许多混淆。简单地说,当两个垂直边界相遇时,它们将形成一个边界。这个边界的高…

    2025年12月23日 好文分享
    000
  • 通过CSS规则禁止选中文字的代码实例

    禁止选中文字在某些场景下还是有必要的,比如不想让他人复制自己的文章之类的。这时候我们可以通过使用css+js来解决这一问题。另外,这边要指出的是,user-select目前还不是w3c的正式标准,各个浏览器都是以私有属性的方式提供支持。 语法 Formal syntax: none | text |…

    好文分享 2025年12月23日
    000
  • 用css设置网页占满屏幕的实例代码

    本文用css设置网页高100%宽100%占满屏幕,可以看一下,挺不错的 css设置网页高100%宽100%占满屏幕*{margin: 0;padding: 0;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing:…

    好文分享 2025年12月23日
    000
  • 一款漂亮的纯CSS手风琴效果代码

    本文分享了纯css实现的手风琴,喜欢的朋友可以看看 源码CSS部分 .accordionMenu {width: 500px;margin: 0 auto;padding: 10px;background-size: #fff;color: #424242;font: 12px Arial, Ver…

    2025年12月23日
    000
  • 如何创造一个水平的滑动模块?网页元素的滑动事件实例代码

    我们还需要完成一些事情,才能搞定这个方法。目前,我们已经实现了触控手势和鼠标拖拽。 function addSlide(element, options) { // Validate arguments… // Resolve element… // Touch supports… …

    好文分享 2025年12月23日
    000
  • 在桌面端和移动端用CSS开启硬件加速实例代码

    你知道我们可以在浏览器中用css开启硬件加速,使GPU (Graphics Processing Unit) 发挥功能,从而提升性能吗? 现在大多数电脑的显卡都支持硬件加速。鉴于此,我们可以发挥GPU的力量,从而使我们的网站或应用表现的更为流畅。 在桌面端和移动端用CSS开启硬件加速 CSS ani…

    好文分享 2025年12月23日
    000

发表回复

登录后才能评论
关注微信