利用css3新增选择器制作背景切换
之前写css3的时间都是捡项目需要的来用,没有系统的学习过,这几天好好的补了一下css3的知识,真的获益匪浅!觉得新增的那些选择器是有用至极的!今天就来所这几天的所学做一个点击标签切换背景的效果,是纯css制作哦,不依赖js,算是作一个总结吧!
首先呢,前期工作当做是要先建好目录那些的了。
index.html、css文件夹(包含style.css)、img文件夹(包含1.jpg,2.jpg,3.jpg,4.jpg)
最后完成的效果如下(因为本人喜欢篮球,所以搞了几张nba人物卡通作素材),具体实现,请看后面的代码!

index.html,结构比较简单,不多做解释
<div class="box">
<img src="img/2.jpg" alt="" id="player2">
<img src="img/3.jpg" alt="" id="player3">
<img src="img/4.jpg" alt="" id="player4">
<img src="img/1.jpg" alt="" id="player1">
<ul>
<li><a href="#player1">科比</a></li>
<li><a href="#player2">詹姆斯</a></li>
<li><a href="#player3">姚明</a></li>
<li><a href="#player4">纳什</a></li>
</ul>
</div>
css:重点讲解一下
body,ul{margin: 0;padding: 0;list-style: none}
.box{position: relative;width: 400px;height: 400px;padding: 10px;margin: 10px auto;border: 1px solid #f0f0f0;box-shadow: 0 0 3px rgba(0,0,0,0.5);overflow: hidden}
.box img{position: absolute;top: 10px;left: 10px;width: 400px;height: 400px}
.box li{display: inline;position: relative;float: left;width: 90px;height: 90px;color: #fff;text-align: center;text-shadow: 0 0 3px rgba(0,0,0,0.9);margin: 280px 4px 0 4px;border: 1px solid #888;cursor: pointer;z-index: 10}
.box li a{display: block;width: 90px;height: 40px;padding: 50px 0 0;color: #fff;text-decoration: none}
.box li:nth-of-type(1){background: #552F86}
.box li:nth-of-type(2){background: #9C0701}
.box li:nth-of-type(3){background: #FFCA34}
.box li:nth-of-type(4){background: #D2C1A6}
.box li a::after{content: '';position: absolute;top: -20px;left: 25px;width: 40px;height: 40px;border-radius: 40px;border: 2px solid #999}
.box li:nth-of-type(1) a::after{background: url(../img/1.jpg) center;background-size: cover}
.box li:nth-of-type(2) a::after{background: url(../img/2.jpg) center;background-size: cover}
.box li:nth-of-type(3) a::after{background: url(../img/3.jpg) center;background-size: cover}
.box li:nth-of-type(4) a::after{background: url(../img/4.jpg) center;background-size: cover}
.box li a::before{content: '';position: absolute;top: -18px;left: 27px;width: 40px;height: 40px;border-radius: 40px;background:rgba(255,255,255,0.3);z-index: 20}
.box li a:hover::before{opacity: 0}
#player1:target{z-index: 10}
#player2:target{z-index: 10}
#player3:target{z-index: 10}
#player4:target{z-index: 10}
img:not(:target){z-index: 5}
看html代码那么简洁,要怎么实现如图所示的看似复杂的效果呢?
1、给每一个人物的小框定义不同的背景色和头像,用到的是结构伪类选择器:nth-of-type() ,头像使用伪元素::after
.box li:nth-of-type(1){background: #552F86}
.box li:nth-of-type(2){background: #9C0701}
.box li:nth-of-type(3){background: #FFCA34}
.box li:nth-of-type(4){background: #D2C1A6}
利用nth-of-type() 为每一个小框定义了不同的颜色。
.box li a::after{content: '';position: absolute;top: -20px;left: 25px;width: 40px;height: 40px;border-radius: 40px;border: 2px solid #999}
.box li:nth-of-type(1) a::after{background: url(../img/1.jpg) center;background-size: cover}
.box li:nth-of-type(2) a::after{background: url(../img/2.jpg) center;background-size: cover}
.box li:nth-of-type(3) a::after{background: url(../img/3.jpg) center;background-size: cover}
.box li:nth-of-type(4) a::after{background: url(../img/4.jpg) center;background-size: cover}
使用了nth-of-type和伪元素after实现了为每一个缩略图设置不同的图片,并且background-size: cover,实现了图片的缩略,使小圆圈里填充满了整张图的效果!
.box li a::before{content: '';position: absolute;top: -18px;left: 27px;width: 40px;height: 40px;border-radius: 40px;background:rgba(255,255,255,0.3);z-index: 20}
.box li a:hover::before{opacity: 0}
以上这段代码呢,是为元素加了蒙板效果,让鼠标移入元素时有点不一样,增强视觉效果!!!
可能人有会觉得奇怪,li里为什么一定要放一个a标签呢?
这就是今天主题的关键所在了!因为我们需要用到最重要的:target,这玩意儿官方是这么解释的:
:target 定义和用法
URL 带有后面跟有锚名称 #,指向文档内某个具体的元素。这个被链接的元素就是目标元素(target element)。
:target 选择器可用于选取当前活动的目标元素。
例子中,URL 带有后面跟有锚名称 #就是 li里的a标签,目标元素就是对应的img
#player1:target{z-index: 10}
#player2:target{z-index: 10}
#player3:target{z-index: 10}
#player4:target{z-index: 10}
就是当点击某个a的时候对应该的img元素就显示在前面,
img:not(:target){z-index: 5}
:not()选择器,是为了去掉某些元素,意思就是不是某类元素的元素生效,:not(:target)即:把不是目标元素的图片显示的下面z-index小于目标元素!
通过如上,便实现了背景切换效果,这可是纯css制作的效果,并没有使用js!
利用css3新增选择器制作背景切换的更多相关文章
- 认识CSS3新增选择器和样式
前端之HTML5,CSS3(二) CSS3新增选择器和样式 CSS3新增选择器 结构伪类选择器 :first-child:选取父元素中的第一个子元素的指定选择器 :last-child:选取父元素中的 ...
- CSS3 新增选择器
CSS3 新增选择器 结构(位置)伪类选择器(CSS3) :first-child :选取属于其父元素的首个子元素的指定选择器 :last-child :选取属于其父元素的最后一个子元素的指定选择器 ...
- CSS系列:CSS3新增选择器
1. CSS1定义的选择器 选择器 类型 说明 E 类型选择器 选择指定类型的元素 E#id ID选择器 选择匹配E的元素,且匹配元素的id为“id”,E选择符可以省略. E.class 类选择器 选 ...
- CSS选择器及CSS3新增选择器
转自:http://www.cnblogs.com/libingql/p/4375354.html 1. CSS1定义的选择器 选择器 类型 说明 E 类型选择器 选择指定类型的元素 E#id ID选 ...
- css3新增属性-background背景
css3新增属性 边框属性 背景属性 文字属性 颜色属性 背景属性 属性 说明 background-image 添加背景图片 background-size 指定背景图像的大小 background ...
- 一起学HTML基础-利用CSS和JavaScript制作一个切换图片的网页
由于个人原因,不详细写步骤 思路: 一.布局 二.制作图片区和按钮区的div及颜色.边框.背景属性等 三.用PS将四张图片剪切到同一个尺寸,重叠放置在图片切换区,透明度设置为0 四.点击对应按钮时,将 ...
- CSS3新增选择器:伪元素选择器
一. ::first-letter 第一个字 二. ::first-line 第一行(以浏览器为准的第一行) 三. ::selection 被选中的字行(鼠标选中的字段)只能向 ::selectio ...
- 利用jquery.backstretch插件,背景切换
//首页自动更换背景特效开始============================================1.引用文件<script src="jquery.js" ...
- css3新增选择器
1. img[alt]:匹配页面标签中任意一个含有alt属性的标签 2. 匹配开头:img[alt^="film"] 匹配包含内容:img[alt*="film" ...
随机推荐
- solr 6.1 服务端 tomcat 搭建及调用
一.下载 apache solr6.1.0 最新版本zip,解压缩生成一个solr6.1.0文件夹 二.安装 1.在d:/projects下新建一个solr 2.把solr6.1.0/server/s ...
- iOS 启动图那些坑
当我们按照图片尺寸要求将所有的图片添加到工程中后,上传打包的工程时可能会出现一个问题:说工程中不存在启动图.但是我们明明已经导入启动图了,那么问题出在哪呢.我经过多次试验,发现压缩过后的图片作为启动图 ...
- css做三角形
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- Android基础:Activity
Activity基本概念 Activity代表活动窗口,通过Context加载页面显示内容,每一个Activity都必须在manifest.xml中注册. 一个应用程序由多个界面构成,回退栈,活动窗口 ...
- Java Script
一.JavaScript简介 1.JavaScript是个什么东西? 它是个脚本语言,需要有宿主文件,它的宿主文件是HTML文件. 2.它与Java什么关系? 没有什么直接的联系,Java是Sun公司 ...
- 第八章 企业项目开发--分布式缓存memcached
注意:本节代码基于<第七章 企业项目开发--本地缓存guava cache> 1.本地缓存的问题 本地缓存速度一开始高于分布式缓存,但是随着其缓存数量的增加,所占内存越来越大,系统运行内存 ...
- 存储过程实现登录(.net)
工作中,可能有时为了安全等的考虑,需要更多 的运用存储过程.有的公司甚至在登录一栏也会提出这样的要求,那么怎么用存储过程实现登录呢.好处就不用言名了,一个速度,一个就是安全系统更高. 下面贴上:1.存 ...
- 关于DButils的简单介绍
android中的orm框架,一行代码就可以进行增删改查:支持事务,默认关闭:可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名)等等 ...
- 用dbforge调试procedure
工具官网地址:http://www.devart.com/dbforge/mysql/studio/ 对于某些存储过程很多且复杂的SQL的应用,在短时间内要使得所有MySQL存储过程和函数正常运行,那 ...
- warning: incompatible implicit declaration of built-in function ‘exit’
出现这个错误,一般是程序中某个函数没有include相关的文件. EG. 出现这个错误是因为要使用exit()应该包含stdlib.h文件