HTML   发布时间:2022-04-14  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了html – 如何仅在嵌套的ul中悬停当前的li?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个嵌套列表:
li:hover {
  BACkground-color: lightgray;
}
ul li ul li:hover {
  font-weight: bold;
}
<ul>
  <li>fnord
    <ul>
      <li>baz</li>
      <li>foo
        <ul>
          <li>baz</li>
          <li>foo</li>
        </ul>
      </li>
    </ul>
  </li>
  <li>gnarf
    <ul>
      <li>baz</li>
      <li>foo
        <ul>
          <li>baz</li>
          <li>yolo</li>
        </ul>
      </li>
    </ul>
  </li>
</ul>

问题是,徘徊“foo”也将悬停“fnord”及其所有li元素.我如何只悬停我的鼠标实际上是在盘旋?

嵌套是可变的,理论上可以是无穷无尽的.

我已经设置了JSFiddle.

解决方法

我相信只有CSS才能获得最接近的是从悬停元素的子项中删除悬停样式……这对父母没有帮助.
li:hover {
    BACkground-color: lightgray;
}
li:hover {
    font-weight: bold;    
}
li:hover ul {
    BACkground-color: white;
    font-weight: normal;
}
<ul>
    <li>fnord
        <ul>
            <li>baz</li>
            <li>foo
                <ul>
                    <li>baz</li>
                    <li>foo</li>
                </ul>
            </li>
        </ul>
    </li>
    <li>gnarf
        <ul>
            <li>baz</li>
            <li>foo
                <ul>
                    <li>baz</li>
                    <li>foo</li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

JSFiddle

您找到的副本上接受的答案是我使用e.stopPropagation:Cascading <li>-hover effect using CSS看到用JavaScript执行此操作的最佳方式.您希望在该选择器中比’all lis’更具体:

$('li').mouseover(function(E)
{
    e.stopPropagation();
    $(this).addClass('currentHover');
});

$('li').mouseout(function()
{
    $(this).removeClass('currentHover');
});
.currentHover {
    BACkground-color: red;
}
li.currentHover ul {
    BACkground-color: white;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="container">
    <li>fnord
        <ul>
            <li>baz</li>
            <li>foo
                <ul>
                    <li>baz</li>
                    <li>foo</li>
                </ul>
            </li>
        </ul>
    </li>
    <li>gnarf
        <ul>
            <li>baz</li>
            <li>foo
                <ul>
                    <li>baz</li>
                    <li>foo</li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

从那里回答JSFiddle.

大佬总结

以上是大佬教程为你收集整理的html – 如何仅在嵌套的ul中悬停当前的li?全部内容,希望文章能够帮你解决html – 如何仅在嵌套的ul中悬停当前的li?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。