zoukankan      html  css  js  c++  java
  • border-radius实现圆弧阴影效果

    1 原理 利用border-radius实现一个圆弧边的矩形,并添加box-shadow,然后放在目标元素的下方

    demo:

    html

    <div class="demo1"></div>

    css

        .demo1{
                    width: 500px;
                    height: 200px;
                    margin: 30px auto;
                    position: relative;
                    background-color: #fff;
                    box-shadow: 0px 0px 3px rgba(0,0,0,0.3),0px 0px 3px rgba(0,0,0,0.2) inset;
                    -webkit-box-shadow:0px 0px 3px rgba(0,0,0,0.3),0px 0px 3px rgba(0,0,0,0.2) inset;
                    -moz-box-shadow:0px 0px 3px rgba(0,0,0,0.3),0px 0px 3px rgba(0,0,0,0.2) inset;
                    -o-box-shadow:0px 0px 3px rgba(0,0,0,0.3),0px 0px 3px rgba(0,0,0,0.2) inset;
                }
                .demo1:after,.demo1:before{
                    position: absolute;
                    content: '';
                    top: 50%;
                    bottom: 0px;
                    left: 10px;
                    right: 10px;
                    z-index: -1;
                    border-radius: 100px/10px;
                    box-shadow: 0px 0px 20px rgba(0,0,0,0.6);
                    -webkit-box-shadow: 0px 0px 20px rgba(0,0,0,0.6);
                    -moz-box-shadow: 0px 0px 20px rgba(0,0,0,0.6);
                    -o-box-shadow: 0px 0px 20px rgba(0,0,0,0.6);
                }

    元素的before after伪元素重贴在一起,加深阴影效果,border-radius:100px/10px;表示水平半径是100px,垂直半径是10px

    ,border-radius的完整写法:border-radius:100px 100px 100px 100px/10px 10px 10px 10px;“/”前的四个数值表示圆角的水平半径,后面四个值表示圆角的垂直半径

     

    demo2:

    .demo2{
                    width: 480px;
                    height: 150px;
                    margin: 30px auto;
                    background-color: red;
                    border-radius: 100px/10px;
                }

    效果:

    实心半圆:

    .demo3{
                    height: 100px;
                    width: 50px;
                    margin: 30px auto;
                    background-color: red;
                    border-radius: 0px 50px 50px 0;
                }

    效果

    翘边阴影

    html

    <div class="demo10">
                <ul>
                    <li><img src="images/1.jpg"></li>
                    <li><img src="images/1.jpg"></li>
                    <li><img src="images/1.jpg"></li>
                </ul>
            </div>

    css

    .demo10{
                    width: 1030px;
                }
                 ul:after{
                    display: block;
                    content: '';
                    clear: both;
                }
                ul li{
                    float: left;
                }
                .demo10 ul li{
                    padding: 10px;
                    border:1px solid #eee;
                    margin-right: 20px;
                    background-color: #fff;
                    box-shadow: 0px 0px 20px rgba(0,0,0,0.1) inset;
                    -webkit-box-shadow: 0px 0px 20px rgba(0,0,0,0.1) inset;
                    -moz-box-shadow: 0px 0px 20px rgba(0,0,0,0.1) inset;
                    -o-box-shadow: 0px 0px 20px rgba(0,0,0,0.1) inset;
                    position: relative;
    
                }
                .demo10 ul li:after{
                    position: absolute;
                    content: "";
                    width: 90%;
                    left: 15px;
                    height: 70%;
                    bottom: 12px;
                    z-index: -1;
                    background-color: transparent;
                    box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    -webkit-box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    -moz-box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    -o-box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    transform:rotate(-5deg) translate(-10px,0);
                    -webkit-transform:rotate(-5deg) translate(-10px,0);
                    -moz-transform:rotate(-5deg) translate(-10px,0);
                    -o-transform:rotate(-5deg) translate(-10px,0);
                }
                .demo10 ul li:before{
                    position: absolute;
                    content: "";
                    width: 90%;
                    right: 15px;
                    height: 70%;
                    bottom: 12px;
                    z-index: -1;
                    background-color: transparent;
                    box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    -webkit-box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    -moz-box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    -o-box-shadow: 0px 0px 25px rgba(0,0,0,.5);
                    transform:rotate(-5deg) translate(-10px,0);
                    -webkit-transform:rotate(5deg) translate(10px,0);
                    -moz-transform:rotate(5deg) translate(10px,0);
                    -o-transform:rotate(5deg) translate(10px,0);
                }
                .demo10 ul li img{
                    width: 300px;
                    height: 200px;
                }

    效果:

  • 相关阅读:
    Gridview如何用自定义按钮进行编辑和提交修改
    winform多线程中给datagridview绑定数据源
    DevExpress控件WebchartControl的学习记录
    datagridview右键选中单元格并获取到焦点
    asp.net局部页面打印,以及如何去掉打印时自动保留的URL地址(页眉页脚)
    GridView如何实现点击某行的指定列弹出新窗体
    C# Color Font 与String之间的转换
    推荐一款 asp.net js日历控件
    js浮点运算替代函数
    VSeWss 1.3 CTP 安装后出现错误
  • 原文地址:https://www.cnblogs.com/xiaofenguo/p/10637168.html
Copyright © 2011-2022 走看看