html - 仅使用 CSS 在悬停时显示下拉菜单并在单击时关闭

标签 html css pointer-events

有人能帮我解释一下为什么当我点击下拉菜单中的链接时它们不起作用吗?也许是因为指针事件?我试图让一个下拉菜单在单击链接或单击关闭按钮后关闭。我添加了一些很酷的东西,比如在单击链接时隐藏父容器。

有很多选择可以做到这一点:

  1. 使用 :focus 但当焦点被使用时,下拉将不会 在下一次悬停在下拉菜单上时触发。

  2. 在容器上使用 :active 并使用 pointer-events 仅指向 事件链接,但指针事件有问题

  3. 使用:target 但是和:focus有同样的问题,不会触发 第二个胡佛。

body {
    padding: 20px;
}
.container {
    border: 1px solid lime;
    padding: 10px;
    width: 200px;
}
.test1 {
    display: none;
    border: 1px dashed orange;
    background: green;
    padding: 10px;
    pointer-events: none;
}
.container:hover .test1 {
    display: inline-block;
}
.container:hover .test1:active {
    display: none;
}
a {
    pointer-events: auto;
    color: lime;
    font-weight: bold;
}
<ul class="container">
	 Drop down menu
	<li class="test1">
	<a class="dropdown" href="#">X Close</a>
	<ul class="content">
		 CLOSE THIS CONTENT
		<li class="link"><a href="http://www.google.com">Go to link 1</a></li>
		<li class="link"><a href="https://www.google.co.uk">Go to link 2</a></li>
		<li class="link"><a href="https://www.google.co.uk">Go to link 3</a></li>
	</ul>

最佳答案

快速检查: Working JSFiddle

Can someone help me with an explanation as to why the links from a dropdown menu are not working when I click on them? Maybe because of pointer events?

解释此行为的原因: 是的,你是对的,这是因为你使用 :active 选择器逻辑的方式,要详细解释,请考虑你的这个 CSS 规则

.container:hover .test1:active {
    display: none;
}

您的菜单链接位于主 li.test1 下,对内部链接的任何点击也会冒泡到此元素,因此与点击 li。因此,只要按住鼠标(鼠标按下事件),它就会触发 :active 事件,并且您隐藏了 links(即:li.test1), 但是只有当鼠标同时按下和向上时点击事件才完成。所以现在 li 已隐藏,mouse up 不再位于链接上。因此,如您所见,没有机会触发点击事件。这就是问题所在。


我看到了您似乎感兴趣的其他答案,这真的不需要任何类型的 hack,只需格式化您的 HTML 并更改一些 CSS 即可完成。


解决方案:与其将内部菜单链接包含在 li.test1 中,不如使用两个不同的 li ,一个用于X CLose,另一个用于保存菜单链接。有了这个,我们可以确保每当 li.test1 处于事件状态时(即鼠标按下)我们可以隐藏它以及其他新的li 与它相邻。因此,这意味着只要用户点击 X Close li,我们就会隐藏菜单,如果他点击其他菜单项,您将被重定向。

所以你的 HTML 结构的变化应该是这样的

<ul class="container">
  Drop down menu
  <li class="test1">
    <a class="dropdown" href="#">X Close</a>
  </li>
  <li class="MenuLinks">
    <ul class="content">
      <!-- all your links go here-->
    </ul>
  </li>
</ul>

主要的 CSS 规则是

.container:hover .test1:active,
.container:hover .test1:active + .MenuLinks {
  display: none;
}

下面是一个 SO 工作片段

body {
  padding: 20px;
}
.container {
  border: 1px solid lime;
  padding: 10px;
  width: 200px;
  list-style-type: none;
}
.test1,
.MenuLinks {  
  display: none;
  border-color: orange;
  border-style: dashed;
  background: green;
  pointer-events: none;
}
.test1 {
  padding: 10px;
  border-width: 1px 1px 0px 1px;
}
.MenuLinks {
  border-width: 0px 1px 1px 1px;
}
.container:hover li {
  display: block;
}

/*Rule to hide both test1 and MenuLinks when X Close is clicked*/
.container:hover .test1:active,
.container:hover .test1:active + .MenuLinks {
  display: none;
}


a {
  pointer-events: auto;
  color: lime;
  font-weight: bold;
}
<ul class="container">
  Drop down menu
  <li class="test1">
    <a class="dropdown" href="#">X Close</a>
  </li>
  <!--seperate li for close-->

  <li class="MenuLinks">
    <!--wrap all your menu items here-->
    <ul class="content">
      CLOSE THIS CONTENT
      <li class="link"><a href="http://www.google.com">Go to link 1</a>
      </li>
      <li class="link"><a href="https://www.google.co.uk">Go to link 2</a>
      </li>
      <li class="link"><a href="https://www.google.co.uk">Go to link 3</a>
      </li>
    </ul>
    <li>
</ul>


注意:当您点击链接时出现黑屏是由于 google 的跨源策略安全限制导致控制台出现此错误

拒绝在框架中显示“https://www.google.co.in/?gfe_rd=cr&ei=x2VWWLL2Ae-K8Qfwx4ngDQ”,因为它将“X-Frame-Options”设置为“SAMEORIGIN”。

但是,当您点击链接时,您可以在网络选项卡中看到请求。

希望这对您有所帮助!

关于html - 仅使用 CSS 在悬停时显示下拉菜单并在单击时关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41062317/

相关文章:

html - 具有 href 属性的 Safari anchor 标签没有获得焦点?

html - 使用 Bootstrap 在 div 中心水平对齐 Font Awesome 图标的最简单方法是什么?

html - 如何在 iframe 中显示 google.com?

android - 为什么当我的桌面屏幕和移动屏幕具有相同的分辨率时,它们显示的内容却不同?

jquery .each(function(index, element)) 不工作?

html - 悬停时链接的多种字体颜色?

javascript - 如何在包装器 div 的鼠标悬停时更改图像

css - 是否可以通过 IFrame 单击?

javascript - 函数在第一次点击后表现异常