javascript - 列表项事件悬停效果

标签 javascript jquery html css hover

我对我的所有列表项都有悬停效果,对我的顶部列表项“推荐”有活跃的悬停效果。当悬停在其他列表项上时,我希望对“推荐”的主动悬停效果取消激活。这样,一次只有一种悬停效果处于事件状态,但如果没有其他悬停效果,则默认的“推荐”链接将始终处于事件状态。

我知道这可能需要一些 jquery?我们将不胜感激任何帮助。

这是我的代码,HTML:

<!DOCTYPE html>
<html>
<head>
    <title>Test</title>
<link rel="stylesheet" type="text/css" href="css/style.css">
<link href="https://fonts.googleapis.com/css?family=Comfortaa" rel="stylesheet">
</head>
<body>
<div class="wrapper">
  <ul>
    <li>
      <a class="testimonials" href="#">
        <h1>testimonials</h1>
        <h2>We love our</h2>
        <div class="selector"><img scr="img/logo.png"></img></div>
      </a>
    </li>
    <li>
      <a class="instructions" href="#">
        <h1>instructions</h1>
        <h2>For your information</h2>
      </a>
    </li>
    <li>
      <a class="Benefits" href="#">
        <h1>benefits</h1>
        <h2>A choice</h2>
      </a>
    </li>
    <li>
      <a class="Top-Recipe" href="#">
        <h1>top</h1>
        <h2>Recommendation</h2>
      </a>
    </li>
    <li>
      <a class="Affiliations" href="#">
        <h1>affiliations</h1>
        <h2>Valued Retailers</h2>
      </a>
    </li>
  </ul>
  </div>
  </body>
  </html>

CSS:

body
{
  margin: 0;
  padding: 0;
  font-family: 'Comfortaa', cursive;
}
.wrapper
{
  position: fixed;
  width: 50%;
  height: 100vh;
  padding-left: 40px;
  padding-right: 40px;
  background: #fff;
}
.wrapper ul
{
position: absolute;
top: 20%;
left: 23%;
right: 10%;
}
.wrapper ul li
{
  list-style: none;
  margin-top: 10%;
}
.wrapper ul li a
{
  text-decoration: none;
  color: #011933;
}
.wrapper ul li a:hover
{
  text-decoration: none;
}
.wrapper ul li a h1
{
  font-size: 28px;
}
.wrapper ul li a h1:hover
{
  font-size: 28px;
  color: #8a6b0c;
}
.wrapper .testimonials
{
  color: #8a6b0c;
}
.wrapper ul li a h2
{
  font-size: 14px;
  margin-left: 20px;
  opacity: .6;

}
.wrapper ul li a h1, h2
{
  width: 50%;
  height: 60px;
  padding: 0;
  display: inline;
}

最佳答案

除了在 .testimonials 类上设置颜色,您可以将其更改为“active”类,并让它在元素和子元素(在本例中为文本)上工作。然后使用 jQuery/JavaScript 来控制事件类的切换。

所以我对 CSS 做了这个:

.wrapper .active *
{
  color: #8a6b0c;
}

代替:

.wrapper .testimonials
{
  color: #8a6b0c;
}

然后像这样用 jQuery 控制切换:

$( "li" ).hover(
  function() {

        if ($('.testimonials')[0].classList.contains('active')) {
            $('.testimonials').toggleClass('active');
      }

    $( this ).toggleClass('active');
  },
  function() {
    $( this ).toggleClass('active');

    if (!$('.testimonials')[0].classList.contains('active')) {
      $('.testimonials').addClass('active');
    }
  }
);

我还在 testimonials 元素的 HTML 中添加了 active 类:

 <a class="testimonials active" href="#">

工作 fiddle :http://jsfiddle.net/f9pqsd8v/10/

关于javascript - 列表项事件悬停效果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51313979/

相关文章:

javascript - 使用“更多”按钮在 AppBar 中显示命令标签

javascript - MooTools Class.extend 有困难

javascript - 单击后退按钮时防止从缓存中加载 Safari

javascript - 请求的脚本资源 'Compat.Timer.Timer.js'需要 'AjaxControlToolkit'版本

javascript - 未指定的错误 DOM IE

html - 文本不在 div 内背景图像的中间

javascript - JS Regex替换所有html标签

javascript - 在 Bottle(框架 jQuery)中导入 Javascript 文件

javascript - 如何将多个 JS 函数合并为一个函数?

css - 带有 CSS 的标题功能区