如何在css背景中添加多个线性渐变?如果

时间:2014-07-18 18:15:08

标签: css3 background-color linear-gradients

我正在尝试完成下面的左侧小部件框,正如您所看到的,有一个对角线性渐变,以及从上到下的光泽。我在CSS中创建的那个是右边的,而我想要完成的那个是在左边。有没有办法只使用一个背景属性来完成这个?或者我需要用另一个div包围整个div,以便我可以在其上覆盖半透明渐变?感谢

enter image description here

更新代码:

.drk-grad {
  background: linear-gradient(to bottom, #d2d2d2 7%, #b1b1b1 100%);
  -webkit-border-radius: 10px;
  border-radius: 10px;
  background-clip: padding-box;
  -webkit-box-shadow: 0px 1px 3px 1px #969494;
  box-shadow: 0px 1px 3px 1px #969494;
  border-top: 1px solid rgba(255, 255, 255, 0.7);
  border-left: 1px solid rgba(255, 255, 255, 0.3);
}

解决方案:

background: repeating-linear-gradient(rgba(255,255,255,.5) -1%, rgba(107, 107, 107, 0.1), repeating-linear-gradient(135deg, #b6b6b6, #B6B6B6 10px, #b2b2b2 10px, #b2b2b2 20px);

1 个答案:

答案 0 :(得分:6)

通常,您可以添加多个背景,以逗号分隔。列出的第一个出现在顶部。

http://css-tricks.com/stacking-order-of-multiple-backgrounds/

http://lea.verou.me/css3patterns/

这是一个基本概要。使用数字播放您想要的效果:

DEMO - http://jsbin.com/tamav/1

.drk-grad {

  background: 

    linear-gradient(to top, transparent, #b1b1b1 100%),

    gray repeating-linear-gradient(45deg, transparent, transparent 35px,

    rgba(255, 255, 255, 0.5) 35px, rgba(255, 255, 255, 0.5) 70px);

  -webkit-border-radius: 10px;
  border-radius: 10px;
  background-clip: padding-box;
  -webkit-box-shadow: 0px 1px 3px 1px #969494;
  box-shadow: 0px 1px 3px 1px #969494;
  border-top: 1px solid rgba(255, 255, 255, 0.7);
  border-left: 1px solid rgba(255, 255, 255, 0.3);

}