简单的单级下拉菜单实现

这里用纯CSS实现一个简单的单级下拉菜单,鼠标划过菜单标题时显示下拉菜单。

基本思路

在菜单处于光标之下时显示菜单,其余时候隐藏。这个过程首先得想到 :hover 伪类来实现,但是直接的利用伪类还不行,因为普通状态下菜单隐藏了,没办法触发 :hover ,不过下拉菜单隐藏了不是还有菜单标题么,菜单标题处于光标之下时显示菜单就能够显示出来了,但是鼠标移到菜单上的时候下拉菜单又会消失,这个时候想到给下拉菜单也加上 :hover 显示自身,但是万一脑洞大开,要做分体菜单怎么办,这个时候把它放进一个容器呗,利用标签的嵌套关系,去给容器的 :hover 伪类的派生元素写样式就一切搞定啦。

上HTML结构

复制代码
 1 <ul id="dropdown-wrapper">  2 <li>  3 <span>Rewrite</span>  4 <ul class="dropdown-sublist">  5 <li>Kotarou</li>  6 <li>Kotori</li>  7 <li>Akane</li>  8 <li>Kagari</li>  9 <li>Lucia</li> 10 <li>Shizuru</li> 11 <li>Chihaya</li> 12 </ul> 13 </li> 14 <li> 15 <span>Clannad</span> 16 <ul class="dropdown-sublist"> 17 <li>Tomoya</li> 18 <li>Nagisa</li> 19 <li>Ushio</li> 20 <li>Ryou</li> 21 <li>Kyou</li> 22 <li>Yukine</li> 23 <li>Fuko</li> 24 <li>Tomoyo</li> 25 <li>Kotomi</li> 26 </ul> 27 </li> 28 <li> 29 <span>Air</span> 30 <ul class="dropdown-sublist"> 31 <li>Yukito</li> 32 <li>Misuzu</li> 33 <li>Kano</li> 34 <li>Minagi</li> 35 </ul> 36 </li> 37 </ul>
复制代码

 

CSS

实现的关键就在那些打惊叹号的规则,写好显示与不显示时两个状态的下拉菜单的属性。同时添加了一些渐变以及平移让菜单显示更加自然。

复制代码
 1 body{ margin:0; padding:0;  2  3  font-size:18px;  4  5  background-color:#aaa;  6 }  7 h1{margin:2em 0.4em 0 0.4em;color:#eee;font-size:3em;}  8 #dropdown-wrapper{  9  display:block; 10 11  margin:4em 1em 0 1em; 12 } 13 #dropdown-wrapper li{ 14 /*!!!!!!!!!!!!*/ 15  display:inline-table; 16  padding:0; 17  margin:0; 18 19  position:relative; 20 21  width:10em; 22 23  background:#fff; 24 25  -webkit-transition:all ease-in-out 0.3s; 26  transition:all ease-in-out 0.3s; 27 } 28 #dropdown-wrapper span{ 29  display:block; 30  padding:0.4em 1em; 31  width:10em; 32  color:#333; 33 } 34 #dropdown-wrapper span:after{ 35  display:inline-block; 36  float:right; 37  content:">"; 38 39  -webkit-transform:rotate(0deg); 40  transform:rotate(0deg);/*为了渐变*/ 41 42  -webkit-transition:all ease-in-out 0.3s; 43  transition:all ease-in-out 0.3s; 44 } 45 #dropdown-wrapper li:hover span:after{ 46  -webkit-transform:rotate(90deg); 47  transform:rotate(90deg);/*划过的时候那个右箭头旋转90度,变成朝下的啦*/ 48 } 49 #dropdown-wrapper li ul{ 50 /*!!!!!!!!!!!!*/ 51  display:block; 52  position:absolute; 53 54  padding:0; 55  margin:0; 56 57  height:0;/*平时的时候隐藏下拉列表*/ 58  line-height:0;/*0行高,这个的作用是用来制造一个文字展开的效果*/ 59  overflow:hidden; 60 61  color:#555; 62 63  opacity:0; 64 65  -webkit-transform:translateY(-1em); 66  transform: translateY(-1em); 67 68  -webkit-transition:all ease-in-out 0.3s; 69  transition:all ease-in-out 0.3s; 70 } 71 #dropdown-wrapper li ul>li{ 72  padding:0.7em 1em; 73 74 } 75 #dropdown-wrapper li:hover ul{ 76 /*!!!!!!!!!!!!*/ 77 /*这是容器处于光标下时的下拉列表的状态, 78 *这个时候就是要做的就是显示下拉菜单咯 79 */ 80 opacity:1; 81 height:auto; 82 line-height:1em; 83 84 -webkit-transform: translaY(0); 85 transform: translateY(0); 86 } 87 #dropdown-wrapper li:hover span{ 88 color:rgb(0,173,238); 89 } 90 #dropdown-wrapper li:hover ul>li:hover{ 91 background:rgb(0,173,238); 92 color:#eee; 93 }
复制代码

转载于:https://www.cnblogs.com/aobingyan/p/3855245.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407524.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#里面的继承

举个例子&#xff1a;有一个基类RectangleEx1 classRectangleEx2 {3 privateint_x, _y, _w, _h;4 5 publicintx6 {7 get{ return_x; }8 set{ _x value; }9 }10 publicinty11 {12 get{ return_y; }13 set{ _y value; }14 }15 publicintw16 {17 get{ return_w; }18 set{ _w value…

Vue-Router的路由实例构造配置

可以通过在创建路由实例的时候传入不同的对象来选择不同的配置&#xff0c;这里的’linkActiveClass’代表的是给被激活的<router-link>添加一个叫做’active’的类名&#xff0c;然后我们就可以在css中给被激活标签设置不同的CSS了 其余的还有

WinForm UI设计与开发思路(转)

最近一年来一直在做WinForm相关的系统&#xff0c;对WinForm的UI设计有一些想法想和大家讨论&#xff08;主要是比较忙&#xff0c;所以很多只是设想&#xff0c;还没有开发实例&#xff09; 关于WinUI&#xff0c;理想的情形应该是外观比较cool&#xff0c;能给用户良好的使用…

Vue之父组件向子组件传递数据

1.创建子组件&#xff0c;在src/components/文件夹下新建一个Child.vue 2.Child.vue的中创建props&#xff0c;然后创建一个名为message的属性 3.在App.vue中注册Child组件&#xff0c;并在template中加入child标签&#xff0c;标签中添加message属性并赋值 4.我们依然可以对m…

Vue之实例的生命周期

Vue实例有一个完整的生命周期&#xff0c;也就是从开始创建、初始化数据、编译模板、挂载Dom、渲染→更新→渲染、卸载等一系列过程&#xff0c;我们称这是Vue的生命周期。通俗说就是Vue实例从创建到销毁的过程&#xff0c;就是生命周期 在Vue的整个生命周期中&#xff0c;它提…

windows遍历目录下所有文件

From: http://blog.csdn.net/benbon/article/details/1911230 在windows中遍历目录下的所有文件主要是使用FindFirstFile和FindNextFile通过递归调用实现的,类似于Linux的opendir和readdir。 在MSDN中&#xff0c;FindFirstFile的声明如下&#xff1a; HANDLE FindFirstFile( …

Vue之计算属性Computed

计算属性将被添加到Vue的实例中。计算属性内部的getter和setter函数内的this上下文将自动地绑定为Vue实例 不应该使用箭头函数来定义计算属性函数 (例如 aDouble: () > this.a * 2)。理由是箭头函数绑定了父级作用域的上下文&#xff0c;所以 this 将不会按照期望指向 Vue …

关于用display:table让元素居中的小结

让元素垂直居中有一种简单的方法:给需要居中的元素用一个父级包起来&#xff0c;并给父元素添加样式’display&#xff1a;table’,同时给这个父级设置好高度,再给需要居中的元素一个display&#xff1a;table-cell,vertical-align:middle;这样被设置的元素就可以做到垂直居中 …

谷歌联合 Adobe 发布 Noto 字体【免费下载】

Noto 涵盖了世界上所有主要语言&#xff0c;包括欧洲&#xff0c;非洲&#xff0c;中东&#xff0c;印度语&#xff0c;南亚和东南亚&#xff0c;中亚&#xff0c;美洲和东亚语言。也支持几个少数民族和历史语言。不久前&#xff0c;还发布了针对文、日文、韩文的开源字体——N…

5月8日全国软考办专家做客51CTO谈:软考政策、考前复习方法及考场技巧

访谈实录>>软考专家访谈实录之一&#xff1a;分数线和通过率是如何确定的&#xff1f;软考专家访谈实录之二&#xff1a;今年的试题会增加难度吗&#xff1f;软考专家访谈实录之三&#xff1a;论文应考秘笈2008年上半年全国软考时间&#xff1a;5月24日、25日。软考临近&…

Vue之引用DOM的ref属性

ref 被用来给DOM元素或子组件注册引用信息。引用信息会根据父组件的 $refs 对象进行注册。如果在普通的DOM元素上使用&#xff0c;引用信息就是元素; 如果用在子组件上&#xff0c;引用信息就是组件实例 注意&#xff1a;只要想要在Vue中直接操作DOM元素&#xff0c;就必须用r…

Vue之$nextTick属性

因为Vue中DOM的更新是异步的&#xff0c;所以一般涉及到DOM的操作都会放在nextTick函数的回调中去执行 将回调延迟到下次 DOM 更新循环之后再执行。在修改数据之后立即使用它&#xff0c;然后等待 DOM 更新之后执行回调。它跟全局方法 Vue.nextTick 一样&#xff0c;不同的是回…