相关文章推荐
打篮球的口罩  ·  将 Visual Studio .NET ...·  6 月前    · 
逆袭的高山  ·  05. Prometheus - ...·  1 年前    · 
谦和的火龙果  ·  java - In Spring Boot ...·  1 年前    · 

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> <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>)
            <li class="nav-item">
                <a class="link" href="./order-list.html">我的订单</a>
            <li class="nav-item">
                <a class="link" href="./user-center.html">我的MMall</a>
            <li class="nav-item">
                <a class="link" href="./about.html">关于MMall</a>
    </div>
</div>
.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>
    <meta charset="utf-8"> 
    <title>类选择器</title> 
    <style> 
    .user.login /* 匹配同时包含user和login的元素 */
        font-size: 35px;
    .user .login{ /* 匹配含user下的含login的元素 */
        background-color:green;
    </style>
    </head>
    <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>