CSS背景颜色和png图像

时间:2012-10-18 14:36:59

标签: css

它可能需要一个解决方法或额外的元素才能实现,但无论如何我都会问。

我有一个简单的图像。图像分为两个对角线。顶部是纯色,底部是透明的。如果我应用以下代码,背景颜色将填充图像的透明度。有没有办法定位颜色或不显示我的图像区域,而只是填充元素的其余部分?

#content:before {
    position: absolute;
    z-index: -1;
    bottom: -35px;
    content: "";
    width: 35px;
    height: 465px;
    left: -35px;
    background: #121314 url(library/images/content-fold-left.png) 0 bottom no-repeat;
}

1 个答案:

答案 0 :(得分:1)

使用CSS3 Gradients:

html, body {
  height: 100%;
}

body {
  background: -webkit-gradient(linear, 50% 0%, 50% 100, color-stop(100%, rgba(0, 0, 0, 0)), color-stop(100%, #fa8072));
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 100px, #fa8072 100px);
  background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 100px, #fa8072 100px);
  background: -o-linear-gradient(top, rgba(0, 0, 0, 0) 100px, #fa8072 100px);
  background: linear-gradient(top, rgba(0, 0, 0, 0) 100px, #fa8072 100px);
}

这是demo

你会注意到我使用了萨斯和指南针。不同的渐变语法是一场噩梦,但是使用Sass和Compass,你只需编写:

body
  +background(linear-gradient(top, rgba(0,0,0,0) 100px, salmon 100px))

它将为您编译所有供应商前缀和不同的遗留语法。