css3-巧用选择器 “:target”

简介: 今天(昨天)又发现一个知识盲区css3的:target标签,之前学习的时候就是一眼扫过,说是认识了,但其实也就记了三分钟,合上书就全忘光了。直到昨天,遇到一个有意思的题目,用css3新特性做一个类似tab标签的小效果,才让我又重新认识了  :target  选择器 w3c上对于target选择器的解释是:试一下他的效果就能对target的作用明白了:http://www.

今天(昨天)又发现一个知识盲区

css3的:target标签,之前学习的时候就是一眼扫过,说是认识了,但其实也就记了三分钟,合上书就全忘光了。

直到昨天,遇到一个有意思的题目,用css3新特性做一个类似tab标签的小效果,才让我又重新认识了  :target  选择器

 

w3c上对于target选择器的解释是:

试一下他的效果就能对target的作用明白了:http://www.w3school.com.cn/tiy/t.asp?f=css_sel_target

原理: 也就是给一个元素A设定id,另一个元素B指定跳转到这个id,然后就向 a:hover 那样,在css中设定 “元素:target”并改变样式,那么点击B元素,就会根据你的设定改变A的样式。

以下就是我根据原理做出来的一个样式

很明显,就是一个tab切换效果,css制作。

代码如下:

html

 1     <div class="swiper-box">
 2         <div class="swiper-cont">
 3             <div class="swiper1" id="swiper1">
 4             </div>
 5             <div class="swiper2" id="swiper2">
 6             </div>
 7             <div class="swiper3" id="swiper3">
 8             </div>
 9         </div>
10         <div class="swiper-num">
11             <a href="#swiper1">1</a>
12             <a href="#swiper2">2</a>
13             <a href="#swiper3">3</a>
14         </div>
15     </div>

css

 1 .swiper-box{
 2     position: relative;
 3     width: 500px;
 4     height: 300px;
 5     margin: 20px auto;
 6     background: #f1f1f1;
 7 }
 8 .swiper-cont div,.swiper1,.swiper2,.swiper3{
 9     width: 0%;
10     height: 300px;
11     position: absolute;
12     top: 0;
13     left: 0;
14     -webkit-transition: width .5s linear;
15     -moz-transition: width .5s linear;
16     -ms-transition: width .5s linear;
17     -o-transition: width .5s linear;
18     transition: width .5s linear;
19 }
20 .swiper1{
21   background: -webkit-linear-gradient(bottom, #fba555, #ffed6c 75%);
22   background: -moz-linear-gradient(bottom, #fba555, #ffed6c 75%);
23   background: -ms-linear-gradient(bottom, #fba555, #ffed6c 75%);
24   background: -o-linear-gradient(bottom, #fba555, #ffed6c 75%);
25   background: linear-gradient(to top, #fba555, #ffed6c 75%);
26 }
27 .swiper2{
28   background: -webkit-linear-gradient(right, #55d5fb, #fd74a7 75%);
29   background: -moz-linear-gradient(right, #55d5fb, #fd74a7 75%);
30   background: -ms-linear-gradient(right, #55d5fb, #fd74a7 75%);
31   background: -o-linear-gradient(right, #55d5fb, #fd74a7 75%);
32   background: linear-gradient(to left, #55d5fb, #fd74a7 75%);
33 }
34 .swiper3{
35   background: -webkit-linear-gradient(bottom right, #55fb69, #6cfff1  75%);
36   background: -moz-linear-gradient(bottom right, #55fb69, #6cfff1  75%);
37   background: -ms-linear-gradient(bottom right, #55fb69, #6cfff1  75%);
38   background: -o-linear-gradient(bottom right, #55fb69, #6cfff1  75%);
39   background: linear-gradient(to top left, #55fb69, #6cfff1  75%);
40 }
41 .swiper-num{
42     position: absolute;
43     bottom: 0;
44     right: 0;
45     display: inline-block;
46     z-index: 9;
47 }
48 .swiper-num a{
49     display: inline-block;
50     margin-left: 10px;
51     padding: 10px 20px;
52     color: #333;
53     font-size: 14px;
54     text-decoration: none;
55     font-weight: bold;
56     background: rgba(255,255,255,.45);
57 }
58 .swiper-num a:hover,.swiper-num a:active{
59     color: red;
60     cursor: pointer;
61     background: rgba(255,255,255,.95);
62 }
63 .swiper-box :target{
64     width: 100%;
65     -webkit-transition: width .5s linear;
66     -moz-transition: width .5s linear;
67     -ms-transition: width .5s linear;
68     -o-transition: width .5s linear;
69     transition: width .5s linear;
70 }
71 .in-cont{
72     height: 60px;
73 }

核心关键点我觉得除了第63行的:target选择器以外,还有就是,所谓的指定target目标id的元素,也就是使用了(href=“#xxx”)属性的元素,一定要是a链接,(比如我div.swiper-num里边的a链接就是zhongdian!!!)

曾经我用span,然后捣鼓到了晚上八点最后明白需要a后才下班。。。

难道href是a的御用吗

 

 

 

 

更多的技巧这篇文章做的很仔细:http://www.css88.com/archives/6256

目录
相关文章
|
10天前
|
缓存 前端开发
CSS基础+基本选择器和复合选择器(如果想知道CSS的基础+基本选择器和复合选择器知识点,那么只看这一篇就足够了!)
CSS基础+基本选择器和复合选择器(如果想知道CSS的基础+基本选择器和复合选择器知识点,那么只看这一篇就足够了!)
|
6天前
|
移动开发 前端开发 HTML5
2024.3.30-认识 CSS (文本样式、复合选择器)
2024.3.30-认识 CSS (文本样式、复合选择器)
|
3天前
|
前端开发
CSS选择器详解与应用实例
CSS选择器详解与应用实例
107 44
|
19天前
|
前端开发 JavaScript
CSS进阶-CSS选择器高级:伪类与伪元素
【6月更文挑战第13天】本文探讨了CSS伪类与伪元素的核心概念,包括伪类表示元素状态,伪元素创造抽象内容。常见问题涉及二者区别、冒号使用、顺序优先级及`content`属性。实践技巧涵盖`:not()`选择器、`:hover`与子元素伪类结合及自定义形状。通过代码示例展示了高亮悬停行、添加图标、首行样式和链接颜色的应用。理解并熟练运用伪类和伪元素可提升CSS设计效率和灵活性。
CSS进阶-CSS选择器高级:伪类与伪元素
|
3天前
|
前端开发 开发者
CSS伪类选择器:增强内容表现力的利器
CSS伪类选择器:增强内容表现力的利器
11 4
|
10天前
|
前端开发
CSS基础之伪元素选择器(如果想知道CSS的伪元素选择器知识点,那么只看这一篇就足够了!)
CSS基础之伪元素选择器(如果想知道CSS的伪元素选择器知识点,那么只看这一篇就足够了!)
|
10天前
|
前端开发
CSS基础之伪类选择器(如果想知道CSS的伪类选择器知识点,那么只看这一篇就足够了!)
CSS基础之伪类选择器(如果想知道CSS的伪类选择器知识点,那么只看这一篇就足够了!)
|
12天前
|
前端开发 JavaScript
CSS id选择器
CSS id选择器
10 1
|
25天前
|
前端开发
CSS基础-CSS选择器:ID、Class、Tag
【6月更文挑战第7天】本文介绍了CSS中的三种基本选择器:ID、Class和Tag选择器。Tag选择器适用于统一设置同类型元素样式,但可能造成样式泛化;Class选择器灵活性高,适合复用,注意命名规范和避免过度使用;ID选择器具有最高优先级,用于唯一标识,应谨慎使用。理解其特点和场景,结合良好命名规范,能提升CSS代码效率和可维护性。
|
25天前
|
Web App开发 移动开发 前端开发
Web网页制作-知识点(3)——HTML5新增标签、CSS简介、CSS的引入方式、选择器、字体属性、背景属性、表格属性、关系选择器 二
Web网页制作-知识点(3)——HTML5新增标签、CSS简介、CSS的引入方式、选择器、字体属性、背景属性、表格属性、关系选择器 二
23 1