作者:保定联通员工 | 来源:互联网 | 2020-09-16 20:46
实现以下菜单效果,当点击公众号弹出4个子菜单,当点击小程序,弹出另外2个子菜单,之前展示的子菜单需要自动收缩起来,且使用纯DIV+CSS,必须使用结构性伪类选择器—target ...
本文目标:
1、掌握CSS中结构性伪类选择器—target的用法
问题:
1、实现以下菜单效果,当点击公众号弹出4个子菜单,当点击小程序,弹出另外2个子菜单,之前展示的子菜单需要自动收缩起来,且使用纯DIV+CSS,必须使用结构性伪类选择器—target
3、写样式 ,创建css文件夹,里面新建index.css,里面的样式怎么写了,以下是分析思路
思路分析:
1、整体容器的子元素
思路分析
1、为了设置容器里的所有元素的公共样式,我们可以将这些公共代码写入.container * 样式内,比如padding,margin,不这样设置的话,然后在每个元素内部去设置,这样会造成代码冗余,所以还是和其他案例一样,先把这个最基础的写起
所以index.css中添加代码如下:
.container *{
padding:0;
margin:0;
}
2、外层容器自身.container
思路分析:
1、根据要求得知宽140,有浅灰色边框,上下左右存有一定的padding
所以index.css中添加代码如下:
.container{
width: 140px;
border: 1px solid lightgray;
padding: 10px;
}
3、标题.title
1、根据要求字体大小16px,颜色浅灰,字体加粗,然后每个标题我们发现它的背景图片是不重复的,且水平方向是靠右,垂直方向是居中,
所以index.css中添加代码如下:
.title{
font-size: 16px;
color:lightgray;
padding:10px;
font-weight: bold;
background-repeat: no-repeat;
background-position-y:center;
background-position-x:right;
}
4、两个标题的单独设置
1、2个标题的不同之处就在于背景图片不同
所以index.css中添加代码如下:
.title1{
background-image: url(../images/1.png);
}
.title2{
background-image: url(../images/5.png);
}
5、菜单.menu
1、一级菜单下面的子菜单首先是要隐藏起来的,只是当点击标题菜单的时候就需要展开,此刻我们可以把子菜单当做是标题菜单的目标即target,而CSS中:target其实表示所有的target,在此文档中target为id=wechataccount和id=applet的2个div,但是每次只对某一个target生效,当另外一个target被触发了,其他的target的样式就会失效,恢复成默认状态,就好像此页面中默认状态是隐藏,但是当公众号点击了,它下面的target就会应用当前的:target样式,但另外一个target触发了,此刻它的样式就又恢复成display:none了
所以index.css中添加代码如下:
.menu{
display: none;
}
:target{
display:block;
}
6、列表公共样式 ul li
1、因为根据实现效果可以看出没有黑色圆点,然后因为每个li都有背景图片,所以一定会有间距padding,且背景图片垂直方向居中,背景图片不重复
所以index.css中添加代码如下:
ul li{
list-style: none;
padding:10px 10px 10px 29px!important;
background-position-y:center;
background-repeat: no-repeat;
}
7、每个li的单独样式
1、每个li的唯一不同就是背景图片不同
所以index.css中添加代码如下:
.li1{
background-image: url(../images/1.png);
}
.li2{
background-image: url(../images/2.png);
}
.li3{
background-image: url(../images/3.png);
}
.li4{
background-image: url(../images/4.png);
}
.li5{
background-image: url(../images/5.png);
}
.li6{
background-image: url(../images/6.png);
}
8、链接设置a
1、每个链接默认是有颜色的,一般为蓝色,但是这里的连接颜色为灰色,不带默认的下划线
所以index.css中添加代码如下:
a{
color:rgb(5, 5, 5);
text-decoration: none;
}
到此为止,index.css的全部内容如下:
.container *{
padding:0;
margin:0;
}
.container{
width: 140px;
border: 1px solid lightgray;
padding: 10px;
}
.title{
font-size: 16px;
color:lightgray;
padding:10px;
font-weight: bold;
background-repeat: no-repeat;
background-position-y:center;
background-position-x:right;
}
.title1{
background-image: url(../images/1.png);
}
.title2{
background-image: url(../images/5.png);
}
.menu{
display: none;
}
:target{
display:block;
}
ul li{
list-style: none;
padding:10px 10px 10px 29px!important;
background-position-y:center;
background-repeat: no-repeat;
}
.li1{
background-image: url(../images/1.png);
}
.li2{
background-image: url(../images/2.png);
}
.li3{
background-image: url(../images/3.png);
}
.li4{
background-image: url(../images/4.png);
}
.li5{
background-image: url(../images/5.png);
}
.li6{
background-image: url(../images/6.png);
}
a{
color:rgb(5, 5, 5);
text-decoration: none;
}
然后将index.css引入index.html中
运行效果如下:
到此为止,我们就实现了全部的需求
总结:
1、学习了CSS中结构性伪类选择器—target的用法
以上就是结构性伪类选择器—target实现可搜索菜单案例(代码实例 )的详细内容,更多请关注 第一PHP社区 其它相关文章!