CSS类选择器参考手册

一个元素同时使用多个类选择器

CSS中类选择器用点号表示。实际项目中一个div元素为了能被多个样式表匹配到(样式复用),通常div的class中由好几段组成,如<div class="user login">能被.user和.login两个选择器选中。如果这两个选择器中有相同的属性值,则该属性值先被改为.user中的值,再被改为.login中的值,即重复的属性以最后一个选择器中的属性值为准。测试如下:

<style>
.user
{
font-size: 30px;
background-color:red;
}
.login
{
background-color:blue;
}
</style>
</head>
<body> <div class='user'>你好。这是一个 DIV 元素,class='user'。</div>
<div class='login'>你好。这是一个 DIV 元素,class='login'。</div>
<div class='user login'>你好。这是一个 DIV 元素,class='user login'。</div> </body>

第三个div元素的背景颜色以.login中的为准,效果如下图:

CSS类选择器的匹配规则

CSS中多个类选择器之间有没有空格是怎样的匹配规则?如.user.login和.user .login(中间有空格)的区别?

直接上例子。电商项目中的导航栏,包括用户的登录/注册/注销,以及购物车等信息。

Html:

<div class="nav">
<div class="w">
<div class="user-info">
<span class="user not-login">
<span class="link js-login">登录</span>
<span class="link js-register">注册</span>
</span>
<span class="user login">
<span class="link-text">
欢迎,
<span class="username"></span></span>
<span class="link">退出</span>
</span>
</div> <!-- 右侧的导航链接 -->
<ul class="nav-list">
<li class="nav-item">
<a class="link" href="./cart.html">
<i class="fa fa-shopping-cart"></i>
购物车(<span class="cart-cont">0</span>)
</a>
</li>
<li class="nav-item">
<a class="link" href="./order-list.html">我的订单</a>
</li>
<li class="nav-item">
<a class="link" href="./user-center.html">我的MMall</a>
</li>
<li class="nav-item">
<a class="link" href="./about.html">关于MMall</a>
</li>
</ul>
</div>
</div>

CSS:

.nav{
background: #eee;
height: 30px;
line-height: 30px;
} /* 用户部分 */
.nav .user{
float: left;
}
.nav .user.login{
display: none;
}
.nav .user .link{
margin-right: 5px;
} /* 导航链接部分 */
.nav .nav-list{
float: right;
}
.nav .nav-list .nav-item{
display: inline-block;
margin-left: 5px;
}

观察上面代码的运行结果可知:

  • .nav .user(中间有空格)匹配到class含有nav的元素下面的class含有user的元素,是<span class="user not-login">和<span class="user login">。
  • .user.login(中间没有空格)匹配到class同时含有user和login的元素,是<span class="user login">。
  • .nav .user.login(.nav和.user中间有空格,.user和.login中间没有空格)匹配到class含有nav的元素下面的class同时含有user和login的元素,是<span class="user login">。

一个更小的例子

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>类选择器</title>
<style>
.user.login /* 匹配同时包含user和login的元素 */
{
font-size: 35px;
} .user .login{ /* 匹配含user下的含login的元素 */
background-color:green;
} </style>
</head>
<body> <div class='user'>你好。这是一个 DIV 元素,class='user'。
<div class='login'>你好。这是一个 DIV 元素,class='user login'。</div>
</div>
<div class='login'>你好。这是一个 DIV 元素,class='login'。</div>
<div class='user login'>你好。这是一个 DIV 元素,class='user login'。</div> </body>
</html>

最新文章

  1. Java的四种引用方式
  2. Windows下的Memcache安装 linux下的Memcache安装
  3. BW系统之间的InfoProvider数据传输:Export DataSource
  4. Robot Framework自动化测试(七)--- jybot模式
  5. HTTP Referer 防外链
  6. 05文件与IO
  7. C程序之修改Windows的控制台颜色(转载)
  8. 求编译器中数的最值(c++)
  9. uva 11624 Fire!(搜索)
  10. 快速定位MS Sql Server 数据库死锁进程
  11. fragment的切换
  12. Java之IO流
  13. OpenLayers学习笔记(十一)— 飞机速度矢量线预测
  14. zeromq学习记录(三)使用ZMQ_PULL ZMQ_PUSH
  15. 踩了的Dockerfile的坑
  16. Linux 保护文件 不给修改
  17. 改变Cube的Shader下的Alpha值,实现Cube若隐若现的效果。
  18. HashMap实现原理分析--面试详谈
  19. 科学技术库Numpy
  20. php guzzle post async

热门文章

  1. java 获取局域网中的全部主机名和IP地址
  2. SQL中实现SPLIT函数几种方法
  3. Android中五种常用的menu
  4. Java 8 – Convert List to Map
  5. 学习Git---20分钟git快速上手
  6. Tomcat7环境下面MySQL 56/Oracle数据库连接池的配置
  7. iOS-一个弹出菜单动画视图开源项目分享
  8. win10下快捷命令
  9. 关于angular的$resource中的isArray属性问题
  10. burpsuite扩展集成sqlmap插件