结构性伪类选择器—target实现可搜索菜单案例(代码实例 )

本文目标:

1、掌握css中结构性伪类选择器—target的用法

问题:

1、实现以下菜单效果,当点击公众号弹出4个子菜单,当点击小程序,弹出另外2个子菜单,之前展示的子菜单需要自动收缩起来,且使用纯DIV+CSS,必须使用结构性伪类选择器—target

实现效果1.png  实现效果2.png

附加说明:

1、整体宽度是140px

2、一级菜单字体16px,加粗显示

现在来具体操作

1、准备素材:根目录创建images文件夹,把相关素材图片都存放与此,我们会发现以上的素材为几张小logo图片,我们准备把它当做背景图片来使用

1.png

2.png

3.png

4.png

5.png

6.png

2、创建好index.html,写好架构,架构如何分析呢

思路分析:

1、目标分成2个部分,每个部分带一个一级菜单,当点击该菜单,需要展示下面的子菜单,而这里我们就可以使用要求的知识点:结构性伪类选择器—target

2、上下两部分都是类似的,只是每个菜单的背景图片不同,所以第二部分很多代码可以复用第一个部分的,但是他们需要单独的设置,所以需要给它们单独设置类名

好,先按照分析,写好思路,暂时不管css的实现

代码如下:

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.png

点击小程序的时候运行效果如下:

实现效果2.png

到此为止,我们就实现了全部的需求

总结:

1、学习了CSS中结构性伪类选择器—target的用法

以上就是结构性伪类选择器—target实现可搜索菜单案例(代码实例 )的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1615254.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 04:49:55
下一篇 2025年12月24日 04:50:08

相关推荐

  • 实现CSS :target伪类选择器的各种应用场景

    实现CSS :target伪类选择器的各种应用场景,需要具体代码示例 CSS : target 伪类选择器是一种常用的CSS选择器,它可以根据URL中的锚点(#)来选择特定的元素。在本文中,我们将介绍一些使用该伪类选择器的实际应用场景,并提供相应的代码示例。 页面内导航链接样式切换: 当用户点击页面…

    2025年12月24日
    000
  • 如何只用css实现点击按钮切换图片

    在css中,可以使用“:target”选择器,配合display属性来实现点击按钮切换图片,只需要给元素设置“元素:target{display:block;}”语句即可。“:target”选择器可用于选取当前活动的目标元素。 本教程操作环境:windows7系统、HTML5&&CS…

    2025年12月24日
    000
  • 你不知道的CSS3目标伪类选择器target(代码实例解析)

    最近在梳理css的知识,发现了很多知识盲区,归根结底还是以前学习的时候低估了css,认为它太简单,应该把重点放在js上面。今天就分享一个实用的css3小知识,即css3:target选择器,还可以用css3:target做一个类似tab的切换效果。相信很多人应该也不熟悉这是属性吧。那继续往下看吧。 …

    2025年12月24日 好文分享
    000
  • Dogwifhat的看涨势头:针对新的高度?

    dogwifhat(wif)展现出积极的上涨信号,在0.83美元附近完成整合后,潜在目标位分别位于1.63美元、2.11美元以及2.69美元。市场情绪与技术面是否将推动其突破? Dogwifhat看涨趋势:能否挑战新高? Dogwifhat(WIF)近期表现出强劲的上升动能,似乎正在酝酿新一轮上涨行…

    2025年12月8日
    100
  • 基于用户控制的oracle热备文件的异机恢复

    测试目的:检测windows下oracle热备文件(含spfile,控制文件,数据文件,归档日志,非rman方式)异机恢复,非原路径下的恢复可用性。测试环境:windows2003R2,O 测试目的:检测windows下oracle热备文件(4 (,6 (,,,al32utf8 7,关闭数据库,启动…

    2025年12月2日 数据库
    000
  • 如何用css:target制作单页导航高亮

    使用 :target 可实现纯 CSS 单页导航高亮,通过 URL 片段激活目标元素样式。1. 导航链接指向带 ID 的内容区;2. 利用 section:target 高亮当前内容;3. 因 CSS 无法反向选中导航,需调整结构,如将 .nav-link 置于目标区域内;4. 通过 .nav-li…

    2025年12月2日 web前端
    000
  • mysql 一个较特殊的问题:You can”t specify target table ‘

    mysql 一个较特殊的问题:You can’t specify target table ‘wms_cabinet_form’ for update in F 今天在写 mysql 遇到一个比较特殊的问题。 mysql 语句如下: update wms_cabi…

    数据库 2025年11月26日
    000

发表回复

登录后才能评论
关注微信