铬中的css线性渐变

时间:2014-02-08 21:32:58

标签: css google-chrome

我尝试在背景中的like this屏幕上显示垂直红线。 在firefox中它可以正常工作,但在chrome 31中,红线丢失了。

我的css代码:

html {
    background-image:
    linear-gradient(90deg, transparent 6em, red 6.2em, red 6em, transparent 6.2em),
    linear-gradient(#eee .1em, transparent .1em);
    background-size: 100% 1.2em;
}

感谢您的帮助。

3 个答案:

答案 0 :(得分:1)

尝试将“-webkit-”添加到那些“线性渐变”前缀以与Chrome兼容,如here所述:

-webkit-linear-gradient(90deg, transparent 6em, red 6.2em, red 6em, transparent 6.2em),
-webkit-linear-gradient(#eee .1em, transparent .1em);

但是,最新的Chrome版本似乎不需要这些前缀。也许你应该更新你的broswer。

答案 1 :(得分:1)

线性渐变是需要供应商指定的众多CSS3属性之一 至少在2014年2月的当前浏览器中。

一个很棒的网站,用于生成CSS3渐变,并提供大量的跨浏览器支持。 HERE

跨浏览器支持示例

background: #1e5799; /* Old browsers */
background: -moz-linear-gradient(top,  #1e5799 0%, #7db9e8 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#1e5799), color-stop(100%,#7db9e8)); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(top,  #1e5799 0%,#7db9e8 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top,  #1e5799 0%,#7db9e8 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top,  #1e5799 0%,#7db9e8 100%); /* IE10+ */
background: linear-gradient(to bottom,  #1e5799 0%,#7db9e8 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1e5799', endColorstr='#7db9e8',GradientType=0 ); /* IE6-9 */

答案 2 :(得分:0)

也许

你使用最新的语法

用颜色填充所有区域(并使用rgb而不是透明,因为我更喜欢它)

使用bakground ssize作为2线性渐变,

它应该可以正常工作:)

http://codepen.io/anon/pen/fpkHE

html {
  background:
    linear-gradient(to right,
      rgba(0,0,0,0) 0,
    rgba(0,0,0,0) 6em, 
    red 6em , 
    red 6.2em ,
    rgba(0,0,0,0) 6.2em,
    rgba(0,0,0,0) 
    ) top left,
    linear-gradient(to bottom,
      #eee .1em, 
      transparent .1em) top ;
  background-size: auto auto ,  100% 1.2em;
  height:100%;/* for test in empty page */
  width:100%;

}