CSS Secret——Backgrounds & Borders

透明边框

如果我们想要一个白色背景和半透明白的边框我们该怎么办呢~
如果你对边框和背景的关系不太了解:

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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值