zoukankan      html  css  js  c++  java
  • Before和After用法小结

    Before和After用法小结

    定义 :before 选择器在被选元素的内容前面插入内容。:after选择器在被选元素的内容后面插入内容。(注:必须包含content 属性)

    一、特性:不能左右:empty伪类

    此表现说明,空元素内部使用伪元素生成的内容,是不被:empty伪类认可的,选择器依然认为这是个空元素
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>不能左右:empty伪类</title>
        <style>
            .box{
                width: 256px;
                height: 90px;
                padding: 10px;
                background-color: red;
                color:#fff;
            }
            .box:empty{
                opacity: .1;
            }
            .pseudo{
                content: "伪元素生成内容";
            }
        </style>
    </head>
    <body>
        <div class="item">
            <div class="title">有内容</div>
            <div class="box">有内容</div>
        </div>
    
        <div class="item">
            <div class="title">无内容</div>
            <div class="box"></div>
        </div>
    
        <div class="item">
            <div class="title">空格也算内容</div>
            <div class="box"> </div>
        </div>
    
        <div class="item">
            <div class="title">伪元素不算内容</div>
            <div class="box pseudo"></div>
        </div>
    </body>
    </html>
    View Code

    二、特性:content动态呈现值无法获取

     
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            body {
                counter-reset: icecream;
            }
            input:checked {
                counter-increment: icecream;
            }
            .total::after {
                content: counter(icecream);
            }
        </style>
    </head>
    <body>
        <strong>下面中国十大冰淇淋你吃过几个?</strong>
        <ul>
            <li><input type="checkbox" id="icecream1"><label for="icecream1">哈根达斯</label></li>
            <li><input type="checkbox" id="icecream2"><label for="icecream2">和路雪wall's</label></li>
            <li><input type="checkbox" id="icecream3"><label for="icecream3">八喜冰淇淋</label></li>
            <li><input type="checkbox" id="icecream4"><label for="icecream4">DQ冰淇淋</label></li>
            <li><input type="checkbox" id="icecream5"><label for="icecream5">蒙牛冰淇淋</label></li>
            <li><input type="checkbox" id="icecream6"><label for="icecream6">雀巢冰淇淋</label></li>
            <li><input type="checkbox" id="icecream7"><label for="icecream7">伊利冰淇淋</label></li>
            <li><input type="checkbox" id="icecream8"><label for="icecream8">乐可可冰淇淋</label></li>
            <li><input type="checkbox" id="icecream9"><label for="icecream9">新城市冰淇淋</label></li>
            <li><input type="checkbox" id="icecream10"><label for="icecream10">明治MEIJI</label></li>
        </ul>
        你总共选择了 <strong class="total"></strong> 款冰淇淋!
    </body>
    </html>
    View Code

    三、用法:清除浮动

     
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .clearfix:before,.clearfix:after { content: "."; display: block; height: 0; visibility: hidden; }
            .clearfix:after {clear: both;} .clearfix {zoom: 1;} /* IE < 8 */
            .box div{width: 200px;height: 200px;background-color: red;margin-right: 20px;margin-bottom: 20px;float: left; }
            .test{clear: both;margin-top: 80px}
        </style>
    </head>
    <body>
        <div class="test">测试一:</div>
        <div class="box"><div></div><div></div></div>
        <div class="box"><div></div><div></div></div>
    
        <!--*********************************************************-->
    
        <div class="test">测试二:</div>
        <div class="box clearfix"><div></div><div></div></div>
        <div class="box"><div></div><div></div></div>
    </body>
    </html>
    View Code

    四、用法:做时间轴

     
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            ul{
                width: 635px;
                height: 100px;
                padding: 20px;
                list-style: none;
                background-color: #f5f5f5;
            }
            li{
                text-align: center;
                position: relative;
                float: left;
                padding: 2px 110px 2px 12px;
            }
            .cusicon{
                margin: 0 auto 15px auto;
                position: relative;
            }
    
            .tip,.time{
                position: absolute;
                left: -40px;
                text-align: center;
                width: 140px;
                font-size: 14px;
            }
            .time{
                top:75px;
                font-size: 12px;
            }
    
            .last:before{
                width: 0!important;
            }
            .cusicon:before{
                content:"";
                width: 100px;
                height: 3px;
                position: absolute;
                top:17px;
                right:-115px;
                background-color: #b3b3b3;
            }
            li.active .cusicon{
                background: url(sprite.png) -0px -72px no-repeat;
                width: 100%;
                height: 100%;
                _background: none;
                _padding-left: 0px;
                _margin-left: -0px;
                _padding-top: 72px;
                _margin-top: -72px;
                _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src="sprite.png");
            }
    
            li.active .cusicon:before{
                background-color: red!important;
            }
            .cusicon {
                height: 36px!important;
                width: 36px!important;
            }
            .cusicon_1 {
                background: url(sprite.png) -0px -0px no-repeat;
                width: 100%;
                height: 100%;
                _background: none;
                _padding-left: 0px;
                _margin-left: -0px;
                _padding-top: 0px;
                _margin-top: -0px;
                _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src="sprite.png");
            }
            .cusicon_2 {
                background: url(sprite.png) -36px -0px no-repeat;
                width: 100%;
                height: 100%;
                _background: none;
                _padding-left: 36px;
                _margin-left: -36px;
                _padding-top: 0px;
                _margin-top: -0px;
                _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src="sprite.png");
            }
            .cusicon_3 {
                background: url(sprite.png) -0px -36px no-repeat;
                width: 100%;
                height: 100%;
                _background: none;
                _padding-left: 0px;
                _margin-left: -0px;
                _padding-top: 36px;
                _margin-top: -36px;
                _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src="sprite.png");
            }
            .cusicon_4 {
                background: url(sprite.png) -36px -36px no-repeat;
                width: 100%;
                height: 100%;
                _background: none;
                _padding-left: 36px;
                _margin-left: -36px;
                _padding-top: 36px;
                _margin-top: -36px;
                _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src="sprite.png");
            }
            .cusicon_5 {
                background: url(sprite.png) -72px -0px no-repeat;
                width: 100%;
                height: 100%;
                _background: none;
                _padding-left: 72px;
                _margin-left: -72px;
                _padding-top: 0px;
                _margin-top: -0px;
                _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src="sprite.png");
            }
        </style>
    </head>
    <body>
    <ul>
        <li class="active">
            <div class="cusicon cusicon_1"></div>
            <div class="tip">
                发布项目
            </div>
            <div class="time">2015-04-02</div>
        </li>
        <li class="active">
            <div class="cusicon cusicon_2"></div>
            <div class="tip">
                设计师报名
            </div>
            <div class="time"></div>
        </li>
        <li>
            <div class="cusicon cusicon_3"></div>
            <div class="tip">
                选择设计师/备案
            </div>
            <div class="time"></div>
        </li>
        <li>
            <div class="cusicon cusicon_4 last"></div>
            <div class="tip">
                确认完工
            </div>
            <div class="time"></div>
        </li>
    </ul>
    </body>
    </html>
    View Code

    五、用法:字体文字(例如ionicfont等)

    六、按钮及布局特效

     
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            html{height: 100%;}
            body{
                margin: 0;
                background-color: #f2f2f2;
                display: flex;
                justify-content: center;
                align-items: center;
                height: 100%;
            }
            .btn{
                width: 570px;
                height: 100px;
                text-align: center;
                line-height: 100px;
                background-color: #fff;
            }
            .btn{position:relative;}
            .btn:before, .btn:after {
                z-index: -1;
                position: absolute;
                content: "";
                bottom: 15px;
                left: 5px;
                width: 50%;
                top: 80%;
                max-width: 300px;
                background: #777;
                -webkit-box-shadow: 0 15px 10px #777;
                -moz-box-shadow: 0 15px 10px #777;
                box-shadow: 0 15px 10px #777;
                -webkit-transform: rotate(-3deg);
                -moz-transform: rotate(-3deg);
                -o-transform: rotate(-3deg);
                -ms-transform: rotate(-3deg);
                transform: rotate(-3deg);
            }
            .btn:after {
                -webkit-transform: rotate(3deg);
                -moz-transform: rotate(3deg);
                -o-transform: rotate(3deg);
                -ms-transform: rotate(3deg);
                transform: rotate(3deg);
                right: 10px;
                left: auto;
            }
    
        </style>
    </head>
    <body>
        <div class="btn"> SIGN IN </div>
    </body>
    </html>
    View Code

    七、兼容性

    • Chrome 2+
    • Firefox 3.5+ (3.0 had partial support)
    • Safari 1.3+
    • Opera 9.2+
    • IE8+ (with some minor bugs
    • 几乎所有的移动浏览器
    • 唯一真正的问题是没有获得支持的(不用奇怪)IE6和IE7

    八、注意事项

    • 由于伪元素不是真正的元素,所以不会出现在DOM中。因此,它们不是可用的。所以,不要使用伪元素生成内容,是您的网页的可用性和可访问性的关键。
    • 由于伪元素难以维护和调试缓慢,所以不要用伪元素显示内容。
  • 相关阅读:
    Kruscal示例程序
    poj 1789 最小生成树prim算法
    取名无力
    最短路dijkstra示例程序
    zoj 1203 最小生成树—kruscal算法
    最小生成树prim算法示例程序
    zoj 1586 最小生成树 prim算法
    poj 1861 Network 最小生成树 kruscal算法
    英国研制出情感机器人能感知主人的悲伤
    微软将发布“群体搜索”
  • 原文地址:https://www.cnblogs.com/xuhang/p/5909149.html
Copyright © 2011-2022 走看看