CSS巧妙的实现CSS斜线的方法

解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的 css 属性,赶紧去补习一下吧。

不断更新,不断更新,不断更新,重要的事情说三遍。

 

8、纯CSS的导航栏Tab切换方案

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

CSS巧妙的实现CSS斜线的方法

立即学习“前端免费学习笔记(深入)”;

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

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

  • 如何接收点击事件

  • 如何操作相关DOM

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

     

    法一::target 伪类选择器

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

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

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

    列表1内容:123456

    列表2内容:abcdefgkijkl

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

    列表1内容:123456

    列表2内容:abcdefgkijkl

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

     。锚点2与之相同对应列表2。

    接下来,我们就可以使用 :target 接受到点击事件,并操作对应的 DOM 了:

    #content1,#content2{    display:none;}#content1:target,#content2:target{    display:block;}

    上面的 CSS 代码,一开始页面中的 #content1 与 #content2 都是隐藏的,当点击列表1触发href="#content1" 时,页面的 URL 会发生变化:

  • 由 www.example.com 变成 www.example.com#content1

  • 接下来会触发 #content1:target{ } 这条 CSS 规则,#content1 元素由 display:none 变成display:block ,点击列表2亦是如此。

    如此即达到了 Tab 切换。当然除了 content1 content2 的切换,我们的 li 元素样式也要不断变化,这个时候,就需要我们在 DOM 结构布局的时候多留心,在 #content1:target 触发的时候可以同时去修改 li 的样式。

    在上面 HTML 的基础上,再修改一下,变成如下结构:

    列表1内容:123456

    列表2内容:abcdefgkijkl

    仔细对比一下与上面结构的异同,这里我只是将 ul 从两个 content 上面挪到了下面,为什么要这样做呢?

    因为这里需要使用兄弟选择符 ~ 。

    E~F{ cssRules } ,CSS3 兄弟选择符(E~F) ,选择 E 元素后面的所有兄弟元素 F。

    注意这里,最重要的一句话是 E~F 只能选择 E 元素 之后 的 F 元素,所以顺序就显得很重要了。

    在这样调换位置之后,通过兄弟选择符 ~ 可以操作整个 .nav 的样式。

    #content1:target ~ .nav li{    // 改变li元素的背景色和字体颜色    &:first-child{        background:#ff7300;        color:#fff;    }}#content2:target ~ .nav li{    // 改变li元素的背景色和字体颜色    &:last-child{        background:#ff7300;        color:#fff;    }}

    上面的 CSS 规则中,我们使用 ~ 选择符,在 #content1:target 和 #content2:target 触发的时候分别去控制两个导航 li 元素的样式。

    至此两个问题,1. 如何接收点击事件 与 2. 如何操作相关DOM 都已经解决,剩下的是一些小样式的修补工作。

     

    法二: && 

    上面的方法通过添加  标签添加页面锚点的方式接收点击事件。

    这里还有一种方式能够接收到点击事件,就是拥有 checked 属性的表单元素,  或者 。

    假设有这样的结构:

    对于上面的结构,当我们点击  单选框表单元素的时候,使用 :checked是可以捕获到点击事件的。

    .nav1:checked ~ .nav li {  // 进行样式操作}

    同样用到了兄弟选择符 ~

    这样,当接收到表单元素的点击事件时,可以通过兄弟选择符 ~ 操作它的兄弟元素的样式。

    可以试着点击下面 codepen 中的单选框。

    但是,这里有个问题 我们的 Tab 切换,要点击的是

  • 元素,而不是表单元素,所以这里很重要的一点是,使用  绑定表单元素。看看如下结构:

    上面的 

  •  中,有一层  ,里面的 for="li1" 意思是绑定 id 为li1 的表单元素。

    label 标签中的 for 定义:for 属性规定 label 与哪个表单元素绑定。

    这样改造之后,当我们点击 

  •  元素的时候,相当于点击了 这个单选框表单元素,而这个表单元素被点击选中的时候,又可以被 :checked 伪类捕获到。

    这个时候,我们就可以将页面上的表单元素隐藏,做到点击 

  •  相当于点击表单:

    input{    display:none;}

    这样,应用到本题目,我们应该建立如下 DOM 结构:

    列表1内容:123456

    列表2内容:abcdefgkijkl

    使用两个单选框,分别对应两个导航选项,运用上面介绍的 label 绑定表单,:checked 接收点击事件,可以得到第二解法。

    到此本文结束,如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

    以上就是CSS巧妙的实现CSS斜线的方法的详细内容,更多请关注创想鸟其它相关文章!

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

  • (0)
    打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
    上一篇 2025年12月23日 21:37:20
    下一篇 2025年12月23日 21:37:31

    相关推荐

    • 使用CSS巧妙地制作背景色渐变动画实例

      解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的 CSS属性,赶紧去补习一下吧。 不断更新,不断更新,不断更新,重要的事情说三遍。 正文从这里开始。有的时候,嗯,应该说某些特定场合,我们可能需要下面这样的动画效果,渐变 + animation : 假设我们渐变的写法如下: …

      2025年12月23日 好文分享
      000
    • 解析CSS3 transition浏览器兼容性

      1、兼容性 根据canius,transition 兼容性如下图所示: p{width:100px;height:100px;background:blue;transition:width 2s;-moz-transition:width 2s; /* Firefox 4 */-webkit-tr…

      2025年12月23日 好文分享
      000
    • 利用CSS实现div水平垂直居中

      实现居中的方案有很多,这里介绍下纯css使用absolute配合margin的方案。 1. p宽高固定 width: 400px;height: 200px;position: absolute;top: 50%;left: 50%;margin-top: -100px;margin-left: -…

      好文分享 2025年12月23日
      000
    • css中background相关属性

      background-origin: 规定 background-position 属性相对于容器的哪一部分来定位。   padding-box 背景图像相对于内边距框来定位;(默认)   border-box背景图像相对于边框盒来定位;   content-box背景图像相对于内容框来定位。 ba…

      好文分享 2025年12月23日
      000
    • CSS中清除浮动的几种方法

      一、clear:both; 这种方法有一个问题:margin失效。 二、隔墙法 /*墙*/ cl{ clear: both; } .hl{ height: 16px; } 演化出的“内墙法” /*两个p都浮动,所以p不会被撑出高*/ /*在家里建一堵墙就能让儿子给p撑出高*/ 注意:一般不使用此方法…

      好文分享 2025年12月23日
      000
    • CSS常用的一些属性详解

      text-align: center”>CSS常用属性 ☛关于css属性个人建议查看手册更加详细方便,我这里就几种常用属性进行分类并简单取几个常用属性值,仅供跟我一样刚学习前端的人作为入门而用。  1.字体样式 字体的缩写,写法是font:font-style|| font-var…

      好文分享 2025年12月23日
      000
    • 关于CSS的优先级和继承问题

      text-align: center”>CSS的优先级和继承问题 ★css的冲突,即优先级  css本身的设置可以同时应用多个样式在同一个元素,此时样式之间可能出现冲突而达不到用户所想要的效果。★解决css冲突的优先级规则:  ● css层叠样式表引入方法的优先级:内联式>内…

      好文分享 2025年12月23日
      000
    • CSS如何实现两端对齐详解

      前面的话   两端对齐在导航nav的制作中非常常用。本文将详细介绍css两端对齐的3种实现方式 flex   弹性盒模型flex作为强大的弹性布局方式,可以hold住大部分的布局效果,当然也包括两端对齐。可以使用主轴对齐justify-content的两端对齐属性space-between just…

      好文分享 2025年12月23日
      000
    • css样式之border-radius详解

      border-radius 属性设置边框的园角     可能的值:像素,百分比 扩展延伸 html代码 css代码 p { height: 200px; width: 200px; border: 2px solid #a72525; border-radius: 10px;} 结果 立即学习“前端…

      好文分享 2025年12月23日
      000
    • 使用css新单位vw,vh在响应式设计中的应用方法

      考虑到未来响应式设计的开发,如果你需要,浏览器的高度也可以基于百分比值调整。但使用基于百分比值并不总是相对于浏览器窗口的大小定义的最佳方式,比如字体大小不会随着你窗口改变而改变,如今css3引入的新单位明确解决这一问题。 css3引入的”vw”和”vh”基于宽度/高度相对于窗口大小,”vw”=”vi…

      好文分享 2025年12月23日
      000
    • 使用css给未知宽高的元素添加背景图片方法

      给页面的某一元素添加背景图片,当没有指定具体的宽高时,是无法显示效果的 1、添加背景图 HTML代码: *{margin:0; padding:0;} #wrap{ width:100%; height:auto; background:url(‘images/page.jpg’) no-repea…

      2025年12月23日 好文分享
      000
    • CSS进阶之CSS的技巧分享

      如何设置水平居中? 分两种情况 行内元素与块级元素     1.行内元素(如图片 文字) div.textcenter{ text-align:center; } hello joe!     2.块级元素     块级元素的水平居中又分为两种 定宽块状元素 和 非定宽块状元素 立即学习“前端免费学…

      2025年12月23日
      000
    • CSS进阶之布局模型实例详解

      css中含有三种布局模型 流动模型flow 浮动模型float 层模型layer 流动模型 网页默认的布局模型 特点有两个   1.块状元素都会在所处的包含元素内自上而下按顺序垂直延伸分布,因为在默认状态下,块状元素的宽度都为100%。实际上,块状元素都会以行的形式占据位置。 h1,p,div{ b…

      2025年12月23日 好文分享
      000
    • box-shadow IE8兼容处理方法介绍

      根据canisue(http://caniuse.com/#search=box-shadow),box-shadow兼容性如下图所示: 测试代码: * { margin: 0; padding: 0; } #header { width: 400px; height: 400px; margin:…

      2025年12月23日 好文分享
      000
    • border-radius IE8兼容处理方法介绍

      根据canisue(http://caniuse.com/#search=border-radius),border-radius兼容性如下图所示: 测试代码: * { margin: 0; padding: 0; } #header { width: 400px; height: 400px; m…

      2025年12月23日 好文分享
      000
    • CSS左边竖条的实现方法代码

      解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的 CSS 属性,赶紧去补习一下吧。 不断更新,不断更新,不断更新,重要的事情说三遍。 题目1、下面这个图形,只使用一个标签,可以有多少种实现方式: 假设我们的单标签是一个 p: Studio Global Studio Glo…

      2025年12月23日 好文分享
      000
    • 使用CSS完美实现垂直水平居中的6种方法介绍

      前言 由于HTML语言的定位问题,在网页中实现居中也不是如word中那么简单,尤其在内容样式多变,内容宽高不定的情况下,要实现合理的居中也是颇考验工程师经验的。网上讲居中的文章很多,但是都不太完整,所以小茄今天就来总结下纯CSS实现居中的各种方案。学疏才浅,文中如有不当之处,万望指出! 6种方案 1…

      2025年12月23日 好文分享
      000
    • 使用CSS创建各种不同的图形形状的方法

      介绍 我们学习如何使用简单的CSS来创建不同类型的平面图形。 使用代码 矩形 .rectangle { width: 250px; height: 150px; background-color: #6DC75F;} 三角形 .triangleUp { border-left: 75px solid…

      2025年12月23日 好文分享
      000
    • 分享12个CSS牛逼的技巧

      下面这些css高级技巧 left-2 list-paddingleft-2″> 使用 :not() 在菜单上应用/取消应用边框 给body添加行高 所有一切都垂直居中 逗号分隔的列表 使用负的 nth-child 选择项目 对图标使用SVG 优化显示文本 对纯CSS滑块使用 max…

      好文分享 2025年12月23日
      000
    • 使用CSS实现div水平垂直居中的方法介绍

      实现居中的方案有很多,这里介绍下纯css使用absolute配合margin的方案。 1. p宽高固定 width: 400px;height: 200px;position: absolute;top: 50%;left: 50%;margin-top: -100px;margin-left: -…

      好文分享 2025年12月23日
      000

    发表回复

    登录后才能评论
    关注微信