- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试实现具有以下功能的菜单:
在我看来,这似乎描述了一个完美的菜单。
我几乎成功地使用了漂亮的 display: table-cell;
技术(为简单起见省略了标签):
<ul>
<li>Menu item</li>
<li>
Expandable ↓
<ul>
<li>Menu</li>
<li>Menu item</li>
<li>Menu item long</li>
</ul>
</li>
<li>Menu item</li>
<li>Menu item</li>
</ul>
ul {
display: table;
table-layout: fixed;
width: 100%;
}
li {
display: table-cell;
text-align: center;
}
li:nth-child(even){
background-color: lightblue;
}
li:nth-child(odd){
background-color: lightskyblue;
}
li ul { display: none; }
li:hover ul {
display: block;
position: absolute;
}
li:hover ul li {
display: block;
}
唯一的问题是子菜单项显示为整页宽度并且部分显示在浏览器窗口之外,从而强制显示水平滚动条:
啊! StackOverflow 不允许我发布图片。在 JSFiddle 上进行实时测试:http://jsfiddle.net/6PTpd/9/
我可以通过添加 float: left; 来解决这个问题clear: both;
到 li:hover ul li
。但是当我这样做时,子菜单项具有不同的宽度:
fiddle :http://jsfiddle.net/6PTpd/10/
...或宽度 width: 15%;
: http://jsfiddle.net/6PTpd/12/
这两个修复都很丑陋,既没有解决等宽问题也没有解决水平滚动条问题。
UPD 在复习这篇文章时,我发现了滚动条问题的一些解决方案:将 li:hover ul
宽度设置为 0。但这会强制指定宽度子菜单项的绝对值。 :( 参见 http://jsfiddle.net/6PTpd/13/
此外,当展开最后一个菜单项时,此解决方案可能会很糟糕。根据屏幕宽度,它可能仍会使页面比窗口更宽:http://jsfiddle.net/6PTpd/15/
问题:
我找到了很多示例,但它们中的每一个都是非拉伸(stretch)的(将元素 float 到左侧)或非动态的(使用从预定义数量的元素中获取的大小,例如 width: 20 %
用于五个一级元素中的每一个,或者更糟的是,使用绝对尺寸!)。
最佳答案
这不是最好的方法,但这是您的解决方案:http://jsfiddle.net/6PTpd/17/
关于 CSS 的有趣之处在于,即使是大师也总是能发现您可以用它做的新事情。从这方面来说,这是一种了不起的语言。这就是为什么我给了你那个 fiddle ,这样你就可以知道你做错了什么(主要是绝对定位,顺便说一句)。但也有一些您应该注意的漏洞。
那么让我解释一下为什么您可能不应该使用该 JSFiddle 中的代码。第一个问题是它使用了 display: none
。这是一个问题,因为屏幕阅读器不会阅读未显示的文本。 (更多信息在这里:http://css-tricks.com/places-its-tempting-to-use-display-none-but-dont/)
第二个问题是它在悬停时显示。在触摸屏越来越普遍的世界里,悬停不再是最佳选择。
如果你愿意,你仍然可以使用它,只是认为你应该知道它的缺点。
TL;DR:如果屏幕阅读器和触摸屏支持是个问题,那么我鼓励您搜索其他选项。
关于html - 寻找一个完美的下拉菜单 : stretching to full width, 等宽项,纯 CSS。请帮忙解决一个故障,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12300715/
我试图通过屏幕截图捕获带有突出显示的元素,但在屏幕截图中,该元素不带有突出显示。有谁知道解决办法吗?当我捕获文本时会出现突出显示:automatests@gmail.com 查看我的代码: Utili
大家好,我是编码的新手,我正在和一位老师一起上 Java 入门课,希望您已经了解一切。我必须对冰雹序列进行编码,它表示为: 选择一些正整数并将其命名为 n。如果 n 是偶数,则将其除以二。如果 n 是
如果存在名称相同的SCOM组,则尝试制作一个请求更多信息(组ID)的脚本: function myFunction { [CmdletBinding()] Param(
我有这张表: id | CUPNAME | FRENCHNAME 1 | 2 | null 2 | null | 4 我想从非空的 CUPNAME 和 FRENCHNAME 中提
我是 Collection View 的新手,想知道这是否是创建它们的最佳方式,我还想了解一些关于从哪里转到启用分页的详细 View 的建议。 #import "MarbleCollectionVie
好的,这是非常好的 jquery slider 。 http://srobbin.com/jquery-plugins/pageslide 我所做的是 http://mbu.mn/test 问题来了。
...有人可以解释一下区别吗? 我在命令提示符下输入的内容: sys.path.append('M:/PythonMods') import qrcode myqr = qrcode.make("ra
我不时在我的服务器上运行 bash 脚本,我正在尝试编写一个脚本来监视日志文件夹并在文件夹超出定义的容量时压缩日志文件。我知道有更好的方法来做我目前正在尝试做的事情,非常欢迎您提出建议。下面的脚本抛出
我是 Groovy & Grails 的新手,我觉得事情不必那么难看……那么我怎样才能让这段代码更好看呢? 这是一个 Grails Controller 类,去掉了一些无趣的部分。尽量不要太挂断我的
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 7年前关闭。 Improve this questi
在这个查询中,除了 5 个连接表之外,我试图使用第 6 个表“Days”将值与连接中的三个表进行比较。但它给了我错误,我不能在连接中使用子查询。 select a.ID, a.Name, a.AMT,
我不想通过 Xpath 提取,我想要更清晰的代码。谢谢我的世界兄弟 来自 Xpath,好的!! Assert.assertEquals("Digite um e-mail ou número de t
这个问题已经有答案了: Google Map is not loading due to inflate exception (3 个回答) 已关闭 9 年前。 我知道有很多关于此的帖子,但我就是无法
我的问题.. a.) 使用内存分配创建一个 float 组来存储 GPA 分数10名学生。为其分配值(您的选择) b.) 找出该数组中的最大 GPA。 c.) 将此数组的内容写入文件 alloc.tx
我最近要制作 Sequelize 。 我有 2 个表,data_track 和 car_detail。我想尝试关联那 2 个表,但它从未关联过。 总是返回错误SequelizeEagerLoading
我有一些代码在 LINQ 中根本无法工作的问题,但它确实可以作为一个简单的 for..each 工作。任何解释和解决方案将不胜感激。 我有 3 个类,Users、User 和 UserPermissi
我正在设计我的第一个大型数据库,并想检查我是否可以提供表关系。 我正在设计一个网络应用程序,其中 用户可以在团队中玩游戏 每个游戏都有其类别 用户为游戏创建他们的团队并选择他们的团队类别 每个游戏都启
我很抱歉成为一个 CSS 菜鸟,希望有人能指导我正确的方向。 我需要帮助的网页可以在 http://filefx.com 找到 当您点击该页面时,您会注意到“选择文件”图标和“上传文件”图标不在同一行
我已经尝试过这个我在网上找到的演示代码练习并创建了这个 slider ,使用滚动条更容易获得它,因为它们已经是为此制作的脚本。现在我正在尝试修改此脚本及其 css,以将滚动条更改为左右两侧的箭头。我已
最近我对 CSS 很感兴趣。学习不同的东西。 我正在尝试像这样放置三个 div: http://i.stack.imgur.com/miN9G.png 我得到的: http://i.stack.img
我是一名优秀的程序员,十分优秀!