首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在完全随机的元素上触发Css悬停

在完全随机的元素上触发Css悬停
EN

Stack Overflow用户
提问于 2017-08-18 15:51:08
回答 3查看 135关注 0票数 0

我正在制作一个嵌套的html菜单。由于某些原因,在你真正悬停在正确的元素上之前,悬停一直在触发。这就像是另一个div或元素提前触发了它。

我认为这与我的HTML结构和我在css中调用悬停的方式有关。

请看下面的代码片段-

代码语言:javascript
复制
/*CAR ASSISTANT STYLES*/

.car-assist-container {
	position: relative;
    float: left;
    width: 210px;
}

.assist-label {
    display: block;
    font-size: 1em;
    float: left;
    padding: 7px;
    text-transform: uppercase;
    color: black;
}

.assist-label:hover > .assist-list {
  opacity: 1;
  height: auto;
}

.assist-list {
  width: 100px;
  background-color: #141825;
  height: 0;
  opacity: 0;
  -moz-transition: all 0.4s ease;
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
  display: block;
}

.assist-item{
    color: white;
    display: block;
    width: 100%;
    padding: 8px;
    border-bottom: 1px solid #1d2435;
    font-family: 'Montserrat', sans-serif;
    font-weight: 100;
    cursor: pointer;
    -webkit-transition: color 0.4s ease;
    -moz-transition: color 0.4s ease;
    -o-transition: color 0.4s ease;
    transition: ocolor 0.4s ease;
}

.assist-item:hover {
	color: #d40000;
}

.browse:after {
	content: '▸';
}

.browse:hover > .browse-list{
	opacity: 1;
}

.browse-list{
    position: absolute;
    right: 0;
    width: 100px;
    background-color: #1d2435;
    top: 0;
    opacity: 0;
    -webkit-transition: opacity 0.4s ease;
    -moz-transition: opacity 0.4s ease;
    -o-transition: opacity 0.4s ease;
    transition: opacity 0.4s ease;
    z-index: -1;
}

.browse-item{
    color: white;
    display: block;
    width: 100%;
    padding: 8px;
    border-bottom: 1px solid #141825;
    font-family: 'Montserrat', sans-serif;
    font-weight: 100;
}

.browse-item:hover {
	color: #d40000;
}
代码语言:javascript
复制
<div class="car-assist-container">
  <a href="#" class="assist-label" id="label">Car Assistant
              <ul class="assist-list">
                <li class="assist-item" id="carWorth">Car Worth</li>
                <li class="assist-item browse">
                  Browse
                  <ul class="browse-list">
                    <li class="browse-item" id="browseMake">Makes</li>
                    <li class="browse-item" id="browseType">Types</li>
                    <li class="browse-item" id="browseYear">Year</li>
                  </ul>
                </li>
                <li class="assist-item">Compare</li>
              </ul>
          </a>
</div>

EN

回答 3

Stack Overflow用户

发布于 2017-08-18 16:07:04

这可能是您想要的行为,只需最少的代码更改。

代码语言:javascript
复制
/*CAR ASSISTANT STYLES*/

.car-assist-container {
	position: relative;
    float: left;
    width: 210px;
}

.assist-label {
    display: block;
    font-size: 1em;
    float: left;
    padding: 7px;
    text-transform: uppercase;
    color: black;
}

.assist-label:hover > .assist-list {
  opacity: 1;
  height: auto;
}

.assist-list {
  width: 100px;
  background-color: #141825;
  height: 0;
  opacity: 0;
  -moz-transition: all 0.4s ease;
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
  display: block;

overflow: hidden;
margin: 0;
}

.assist-item{
    color: white;
    display: block;
    width: 100%;
    padding: 8px;
    border-bottom: 1px solid #1d2435;
    font-family: 'Montserrat', sans-serif;
    font-weight: 100;
    cursor: pointer;
    -webkit-transition: color 0.4s ease;
    -moz-transition: color 0.4s ease;
    -o-transition: color 0.4s ease;
    transition: ocolor 0.4s ease;
}

.assist-item:hover {
	color: #d40000;
}

.browse:after {
	content: '▸';
}

.browse:hover > .browse-list{
	opacity: 1;
    height: auto;

}

.browse-list{
    position: absolute;
    right: 0;
    width: 100px;
    background-color: #1d2435;
    top: 0;
    opacity: 0;
    -webkit-transition: opacity 0.4s ease;
    -moz-transition: opacity 0.4s ease;
    -o-transition: opacity 0.4s ease;
    transition: opacity 0.4s ease;
    z-index: 1;
    height: 0;
    overflow: hidden;
}

.browse-item{
    color: white;
    display: block;
    width: 100%;
    padding: 8px;
    border-bottom: 1px solid #141825;
    font-family: 'Montserrat', sans-serif;
    font-weight: 100;
}

.browse-item:hover {
	color: #d40000;
}
代码语言:javascript
复制
<div class="car-assist-container">
  <a href="#" class="assist-label" id="label">Car Assistant
              <ul class="assist-list">
                <li class="assist-item" id="carWorth">Car Worth</li>
                <li class="assist-item browse">
                  Browse
                  <ul class="browse-list">
                    <li class="browse-item" id="browseMake">Makes</li>
                    <li class="browse-item" id="browseType">Types</li>
                    <li class="browse-item" id="browseYear">Year</li>
                  </ul>
                </li>
                <li class="assist-item">Compare</li>
              </ul>
          </a>
</div>

票数 1
EN

Stack Overflow用户

发布于 2017-08-18 16:30:14

这是因为您的.browse-list div位于.assist-label的顶部,所以当您将鼠标悬停在.assist-label上时,实际上是在.browse-list上悬停。

票数 0
EN

Stack Overflow用户

发布于 2017-08-18 16:34:20

您正在设置不透明度的动画,我已将其从display: block更改为display: none;我们现在将这些值切换到悬停状态。似乎是在正确的时机触发的。然而,你的子菜单仍然不能正常工作,但我没有调查,因为这不是问题;-)

代码语言:javascript
复制
/*CAR ASSISTANT STYLES*/

.car-assist-container {
	position: relative;
    float: left;
    width: 210px;
}

.assist-label {
    display: block;
    font-size: 1em;
    float: left;
    padding: 7px;
    text-transform: uppercase;
    color: black;
}

.assist-label:hover > .assist-list {
  opacity: 1;
  height: auto;
display:block;
}

.assist-list {
  width: 100px;
  background-color: #141825;
  height: 0;
  opacity: 0;
  -moz-transition: all 0.4s ease;
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
  display: none;
}

.assist-item{
    color: white;
    display: block;
    width: 100%;
    padding: 8px;
    border-bottom: 1px solid #1d2435;
    font-family: 'Montserrat', sans-serif;
    font-weight: 100;
    cursor: pointer;
    -webkit-transition: color 0.4s ease;
    -moz-transition: color 0.4s ease;
    -o-transition: color 0.4s ease;
    transition: ocolor 0.4s ease;
}

.assist-item:hover {
	color: #d40000;
}

.browse:after {
	content: '▸';
}

.browse:hover > .browse-list{
	opacity: 1;
    display:block;
}

.browse-list{
    position: absolute;
    right: 0;
    width: 100px;
    background-color: #1d2435;
    top: 0;
    opacity: 0;
    display:none;
    -webkit-transition: opacity 0.4s ease;
    -moz-transition: opacity 0.4s ease;
    -o-transition: opacity 0.4s ease;
    transition: opacity 0.4s ease;
    z-index: -1;
}

.browse-item{
    color: white;
    display: block;
    width: 100%;
    padding: 8px;
    border-bottom: 1px solid #141825;
    font-family: 'Montserrat', sans-serif;
    font-weight: 100;
}

.browse-item:hover {
	color: #d40000;
}
代码语言:javascript
复制
<div class="car-assist-container">
  <a href="#" class="assist-label" id="label">Car Assistant
              <ul class="assist-list">
                <li class="assist-item" id="carWorth">Car Worth</li>
                <li class="assist-item browse">
                  Browse
                  <ul class="browse-list">
                    <li class="browse-item" id="browseMake">Makes</li>
                    <li class="browse-item" id="browseType">Types</li>
                    <li class="browse-item" id="browseYear">Year</li>
                  </ul>
                </li>
                <li class="assist-item">Compare</li>
              </ul>
          </a>
</div>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45751335

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档