html导航页面转换,纯CSS实现导航栏Tab切换效果

本文介绍了如何使用纯CSS,不依赖JavaScript,实现导航栏Tab切换的效果。通过`:target`伪类选择器和`input[type="radio"]`结合`label`元素,详细解析了两种不同的实现方法,包括接收点击事件和操作DOM的CSS技巧。
摘要由CSDN通过智能技术生成

不用 Javascript,使用纯 CSS 方案,实现类似下图的导航栏切换:

9d4fd00d59bc0ce1bb95bf70a2a6119c.gif

CSS 的强大之处有的时候超乎我们的想象,Tab 切换,常规而言确实需要用到一定的脚本才能实现。下面看看如何使用 CSS 完成同样的事情。

实现 Tab 切换的难点在于如何使用 CSS 接收到用户的点击事情并对相关的节点进行操作。即是:

如何接收点击事件

如何操作相关DOM

下面看看如何使用两种不同的方法实现需求:

法一::target 伪类选择器

首先,我们要解决的问题是如何接收点击事件,这里第一种方法我们采用 :target 伪类接收。

:target 是 CSS3 新增的一个伪类,可用于选取当前活动的目标元素。当然 URL 末尾带有锚名称 #,就可以指向文档内某个具体的元素。这个被链接的元素就是目标元素(target element)。它需要一个 id 去匹配文档中的 target 。

解释很难理解,看看实际的使用情况,假设我们的 HTML 代码如下:

CSS Code复制内容到剪贴板

列表1列表2
列表1内容:123456
列表2内容:abcdefgkijkl

由于要使用 :target,需要 HTML 锚点,以及锚点对应的 HTML 片段。所以上面的结构要变成:

CSS Code复制内容到剪贴板

列表1 列表2
列表1内容:123456
列表2内容:abcdefgkijkl

这样,上面 中的锚点 #content1 就对应了列表1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值