您的位置:首页 > Web前端 > CSS

CSS Secret——Backgrounds & Borders

2016-06-25 20:56 337 查看

透明边框

如果我们想要一个白色背景和半透明白的边框我们该怎么办呢~

如果你对边框和背景的关系不太了解:

border: 10px solid hsla(0,0%,100%,.5);
background: white;


这样你是看不到透明边框的,因为背景本身是会铺到边框里的。

使用background-clip: padding-box;可以使背景只铺到内边距。

border: 10px solid rgba(255, 0, 255, 0.3);
background: white;
background-clip: padding-box;


多重边框

使用阴影

之前都用好几个元素套起来的办法来实现多重边框,其实使用多个阴影就能实现。

#muti-border{
height:20px;
background: yellowgreen;
margin:15px;
box-shadow: 0 0 0 10px #655,
0 0 0 15px deeppink,
0 2px 5px 15px rgba(0,0,0,.6);
}


这样每个阴影都会显示并叠起来,就像多个边框了。

这里有个问题要注意,阴影不同于border,它的宽度是不在盒模型中的,也就是说你的假阴影可能会覆盖在别的元素上。你可以使用和阴影相同宽度的内边距和外边距来模拟这一点(你的阴影如果是往里叠的就要使用内边距了)。往里叠有个好处,就是这个元素的点击,鼠标进入等事件在你的假边框上都会触发。但是如果你是往外叠的,那这个元素上的事件在假边框上就触发不了了。

使用outline

如果你只需要两个边框,可以使用outline来模拟。这个outline不仅可以设置与元素边界的距离(正负都行),还可以设置像border一样的style,刚才的方法只能模拟solid。

#outline-border{
background: #655;
border: 10px solid #655;
outline: 1px dashed #fff;
outline-offset:-15px;
height:100px;
width:200px;
border-radius: 10px;
color:#fff;
margin:30px;
padding:10px;
}


这个方法最大的限制就是outline只能有一个。

还有一个问题就是outline不贴着圆角,它永远是方的。

灵活的背景位置

我们现在在设置background-position时使用的一般是关键字和相对左上角的偏移量。

想象这样一个使用场景,一个宽高不定的div,我们想让一个背景相对右下角有一个固定的位置,但要有一点距离不贴边。

啊哦。

拓展background-position

在CSS Backgrounds & Borders Level 3中,在关键词后提供偏移量可以指定从哪里偏移。不过,为了兼容老的浏览器,要提供回滚值哦。

#background{
background: url(../img/marker_red.png) no-repeat bottom right #58a;
background-position: right 20px bottom 10px;
height:100px;
}


background-origin方案

当我们规定background-position时的相对位置由这个属性来控制,默认为padding box,如果改为content-box就可以使用padding来直接控制background相对于外面的距离了。

padding: 10px; background: url(../img/marker_red.png) no-repeat #58a bottom right; /* or 100% 100% */
background-origin: content-box;


同样,现在在关键字后加上offset还是可以继续调整的。

使用calc()

这个神奇的函数可以跨单位的计算值哦。

background: url("code-pirate.svg") no-repeat;
background-position: calc(100% - 20px) calc(100% - 10px);


内部圆角

我们有时需要一个外圆内方的元素~~

使用两个div来达成目标很容易,但是这吗,明明应该是一个元素呀。

我们首先使用outline永远是矩形不跟随边框圆角的特性。

#rect-round{
background: tan;
border-radius: .8em;
padding: 1em;
outline: .7em solid #655;
margin:20px;
width:20%;
}


这样就在圆角的元素外面套了一个矩形的框,但是这里会有个问题,圆角和框之间的空隙是没有被填上的。

这时就使用不带模糊的box-shadow,这个是会贴合圆角的。outline和box-shadow都不占框模型,它们会重合,这样圆角和框之间的缝就填上了。

#rect-round{
background: tan;
border-radius: .8em;
padding: 1em;
box-shadow: 0 0 0 .6em #655;
outline: .7em solid #655;
margin:20px;
width:20%;
}


条纹背景

创建条纹背景以前从来都是使用图片来解决的。

不过其实我们可以使用渐变背景来达成目的。

linear-gradient这个东西其实就是个由浏览器解析生成的背景图片。

利用这一点:

水平条纹

#striped{
height:200px;
background: linear-gradient(#fb3 50%, #58a 50%);
background-size: 100% 30px;
}


这里我们创建了一个毫无过渡的,30px高的线性过度背景,因为背景是可以repeat的,所以就有了全背景的条纹效果。

通过这样设置可以创建不均匀的条纹:

#striped{
height:200px;
background: linear-gradient(#fb3 30%, #58a 0%);
background-size: 100% 30px;
}


多个条纹:

#striped{
height:200px;
background: linear-gradient(#fb3 33.3%,
#58a 33.3%, #58a 66.6%, yellowgreen 66.6%);
background-size: 100% 45px;
}


垂直条纹

垂直条纹就是使用有角度的线性渐变

#striped{
height:200px;
background: linear-gradient(to right, /* or 90deg */
#fb3 50%, #58a 0);
background-size: 30px 100%;
}


倾斜条纹

#striped{
height:200px;
background: repeating-linear-gradient(60deg,
#fb3 0, #fb3 15px, #58a 0, #58a 30px);
}


使用透明色来更灵活的创建条纹

有时我们创建的条纹只有细微的差别,那么使用纯色背景加半透明条纹就很方便改主题,而且对不支持渐变的浏览器还很方便的提供了一个fallback。

#striped{
height:200px;
background: #58a;
background-image: repeating-linear-gradient(30deg,
hsla(0,0%,100%,.1),
hsla(0,0%,100%,.1) 15px,
transparent 0, transparent 30px);
}


复杂背景

网格

同时使用垂直和水平,可以创造出很神奇的效果呢~

#grid1{
height:200px;
background: white;
background-image: linear-gradient(90deg, rgba(200,0,0,.5) 50%, transparent 0),
linear-gradient(rgba(200,0,0,.5) 50%, transparent 0);
background-size: 30px 30px;
}
#grid2{
height:200px;
background: #58a;
background-image:
linear-gradient(white 1px, transparent 0),
linear-gradient(90deg, white 1px, transparent 0);
background-size: 30px 30px;
}
#grid3{
height:200px;
background: #58a;
background-image:
linear-gradient(white 2px, transparent 0),
linear-gradient(90deg, white 2px, transparent 0),
linear-gradient(hsla(0,0%,100%,.3) 1px,transparent 0),
linear-gradient(90deg, hsla(0,0%,100%,.3) 1px,transparent 0);
background-size: 75px 75px, 75px 75px,15px 15px, 15px 15px;
}


点点嗷

如果需要点点的背景,使用radial-gradient来创建是很不错的呦。

这里使用了sass,这样可以创建不同的各种各样的点点

@mixin polka($size, $dot, $base, $accent) {
background: $base;
background-image:
radial-gradient($accent $dot, transparent 0),
radial-gradient($accent $dot, transparent 0);
background-size: $size $size;
background-position: 0 0, $size/2 $size/2;
}
#dot{
height:200px;
@include polka(50px, 20%, #655, tan);
}


西洋棋盘

这个直接通过方块并不很好实现,通过把方块分成两个三角形比较好实现。

background-image:
linear-gradient(45deg, #bbb 25%, transparent 0),
linear-gradient(45deg, transparent 75%, #bbb 0),
linear-gradient(45deg, #bbb 25%, transparent 0),
linear-gradient(45deg, transparent 75%, #bbb 0);
background-position: 0 0, 15px 15px,
15px 15px, 30px 30px;
background-size: 30px 30px;


进一步合并,使用sass:

@mixin checkerboard($size, $base, $accent: rgba(0,0,0,.25) {
background: $base;
background-image:
linear-gradient(45deg,
$accent 25%, transparent 0,
transparent 75%, $accent 0),
linear-gradient(45deg,
$accent 25%, transparent 0,
transparent 75%, $accent 0);
background-position: 0 0, $size $size,
background-size: 2*$size 2*$size;
}
@include checkerboard(15px, #58a, tan);


不过呢,这个使用svg的话会更方便:

background: #eee url('data:image/svg+xml,\
<svg xmlns="http://www.w3.org/2000/svg" \
width="100" height="100"
fill-opacity=".25">\
<rect x="50" width="50" height="50" /> \
<rect y="50" width="50" height="50" /> \
</svg>');
background-size: 30px 30px;


伪随机背景

利用素数,使重复的区间足够长,达到随机条纹的目的

#random{
height:200px;
background: hsl(20, 40%, 90%);
background-image:
linear-gradient(90deg, #fb3 11px, transparent 0),
linear-gradient(90deg, #ab4 23px, transparent 0),
linear-gradient(90deg, #655 41px, transparent 0);
background-size: 41px 100%, 61px 100%, 83px 100%;
}


连续的图片边框

我们想让内容浮在一张图片上,这张图片就像是内容的边框一样。

border-image可是实现不了的哦。

#border-image{
padding: 1em;
border: 1em solid transparent;
background: linear-gradient(white, white),url(../img/stone-art.jpg);
background-size: cover;
background-clip: padding-box, border-box;
background-origin: border-box;
}


同样的原理,可以用来模拟信封边框的样式:

#border-image1{
height: 200px;
padding: 1em;
border: 1em solid transparent;
background: linear-gradient(white, white) padding-box,
repeating-linear-gradient(-45deg,red 0, red 12.5%,
transparent 0, transparent 25%,
#58a 0, #58a 37.5%,
transparent 0, transparent 50%)
0 / 5em 5em;
}


配合动画,可以做出想ps里选区虚线框那样的动画。

@keyframes ants { to { background-position: 100% } }
#border-image2 {
padding: 1em;
border: 1px solid transparent;
background:
linear-gradient(white, white) padding-box,
repeating-linear-gradient(-45deg,black 0, black 25%, white 0, white 50%) 0 / .6em .6em;
animation: ants 120s linear infinite;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  背景 边框 CSS3