CSS实现多重边框
2017-06-28 本文已影响0人
zJ_16
实现这样的效果 简单
data:image/s3,"s3://crabby-images/0871a/0871acc5ffa4551ef396ebb379765fd1ae9b1d7d" alt=""
.box {
width: 150px;
display: flex;
justify-content: center;
align-items: center;
height: 200px;
background-color: lightskyblue;
border: 20px solid royalblue;
}
<div class="box">
box
</div>
但要实现这样的效果,不包裹div的前提下,使用outline属性
data:image/s3,"s3://crabby-images/6ea40/6ea40d6f2303a8a8c05ac8b963e341deaed7a488" alt=""
.box {
width: 150px;
display: flex;
justify-content: center;
align-items: center;
height: 200px;
background-color: lightskyblue;
border: 20px solid royalblue;
outline: solid 20px brown;
}
但要实现这样的效果 outline 是不行的
data:image/s3,"s3://crabby-images/920b9/920b9d2256bd3bb2d07fdf3ce63396edb0eda272" alt=""
如果使用 outline 只会这样
.box {
width: 150px;
display: flex;
justify-content: center;
align-items: center;
height: 200px;
background-color: lightskyblue;
border: 20px solid royalblue;
border-radius: 30px;
outline: solid 20px brown;
}
data:image/s3,"s3://crabby-images/2b52c/2b52c1421c72484a05cf22f1d3487f6adb7f2724" alt=""
但是用阴影 box-shadow 可以做到 就像这样
.box {
width: 150px;
display: flex;
justify-content: center;
align-items: center;
height: 200px;
background-color: lightskyblue;
border: 20px solid royalblue;
border-radius: 30px;
box-shadow: 0 0 0 20px brown;
}
data:image/s3,"s3://crabby-images/c9348/c9348bc5dab718e038f43cd977a6e989bf6c5568" alt=""
还能这样
.box {
width: 150px;
display: flex;
justify-content: center;
align-items: center;
height: 200px;
background-color: lightskyblue;
border: 20px solid royalblue;
border-radius: 30px;
box-shadow: 0 0 0 20px brown,
0 0 0 40px salmon,
0 0 0 60px crimson;
}
data:image/s3,"s3://crabby-images/9654e/9654e5f9f3adaa24ee685f5d058ffb09811a2853" alt=""