2013-11-04 54 views
1

我使用IE 8,而不是CSS3,我想知道,我有幾個我可以在IE8中爲​​創建CSS漸變背景嗎?

<td> 

標籤和我目前的CSS

td { 
    background-color: blue; 
} 

有沒有一種方法來創建漸變對於IE 8,沒有CSS3的td的背景?我試圖

td { 
    background-image: -o-linear-gradient(bottom, rgb(254,133,107) 24%, rgb(35,171,17) 62%); 
} 

td { 
    background-image: linear-gradient(bottom, rgb(254,133,107) 24%, rgb(35,171,17) 62%); 
} 

,但他們都沒有爲我工作。

現在,我知道我可以給背景圖片和Photoshop一個漸變,但事情是,我的td尺寸不是恆定的,一個td可能有一個150px的高度,一個可能有一個90px的高度,一個可能寬度爲150像素,寬度爲90像素。我需要一個適用於所有td的通用代碼,無論它們的高度和寬度如何。

有沒有辦法讓td的background-image自動成爲td的寬度和高度,即使td的寬度和高度沒有被指定,並且它只取決於多少文本在td裏面?

+0

[用於梯度IE8 +最少需要CSS(可能重複http://stackoverflow.com/questions/17201785/minimum- css-required-for-gradients-ie8) – Spudley

+0

'-o-linear-gradient'用於舊版本的Opera(在它們切換到使用Blink引擎之前)。 –

回答

5

IE 8不支持舊的,無效的,特定於Microsoft的CSS漸變語法。它不提供適當CSS漸變的所有功能(例如,您不能指定停止位置),所以您將無法完全匹配您獲得的漸變。

http://msdn.microsoft.com/en-us/library/ms532997(v=vs.85).aspx

這是你梯度的粗略估計:

td { 
    filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#FE856B, endColorStr=#23AB11); 
} 
+1

啊完美,它的工作原理。謝謝! – user2719875

+1

*是* CSS(特定於Microsoft的非標準CSS)。這是IE 8支持的唯一CSS漸變語法。如果有另一個,互聯網現在會聽說它。 –

+0

另一方面,如果瀏覽器特別是IE 9之前,他們是否有新的方式來爲IE 9和IE 10做同樣的事情? – user2719875

2

當我需要做一個CSS梯度我通常使用this的網站,因爲它提供了你所有的CSS爲它所有的瀏覽器

+0

哼,那不是CSS3?另外,當我得到它時,它說:「看起來你的瀏覽器不完全支持CSS漸變,你需要最新版本的Firefox,Chrome或Safari來使用這個工具。」 – user2719875

0

工作,如果你想顯示一個背景紋理到TD:

CSS 2級

td { 
    background-image: transparent url(a-real-image.img) repeat-x 0 0; 
} 

CSS 3級

td { 
    background: rgb(30,87,153); /* Old browsers */ 
    background: linear-gradient(to bottom, rgba(30,87,153,1) 0%,rgba(41,137,216,1) 50%,rgba(32,124,202,1) 51%,rgba(125,185,232,1) 100%); /* W3C */ 
} 

CSS專利(其中 '過濾器:' 將對付微軟IE 6-8最後一行])

td { 
    background: rgb(30,87,153); /* Old browsers */ 
    /* IE9 SVG, needs conditional override of 'filter' to 'none' */ 
    background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzFlNTc5OSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjUwJSIgc3RvcC1jb2xvcj0iIzI5ODlkOCIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjUxJSIgc3RvcC1jb2xvcj0iIzIwN2NjYSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiM3ZGI5ZTgiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+); 
    background: -moz-linear-gradient(top, rgba(30,87,153,1) 0%, rgba(41,137,216,1) 50%, rgba(32,124,202,1) 51%, rgba(125,185,232,1) 100%); /* FF3.6+ */ 
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(30,87,153,1)), color-stop(50%,rgba(41,137,216,1)), color-stop(51%,rgba(32,124,202,1)), color-stop(100%,rgba(125,185,232,1))); /* Chrome,Safari4+ */ 
    background: -webkit-linear-gradient(top, rgba(30,87,153,1) 0%,rgba(41,137,216,1) 50%,rgba(32,124,202,1) 51%,rgba(125,185,232,1) 100%); /* Chrome10+,Safari5.1+ */ 
    background: -o-linear-gradient(top, rgba(30,87,153,1) 0%,rgba(41,137,216,1) 50%,rgba(32,124,202,1) 51%,rgba(125,185,232,1) 100%); /* Opera 11.10+ */ 
    background: -ms-linear-gradient(top, rgba(30,87,153,1) 0%,rgba(41,137,216,1) 50%,rgba(32,124,202,1) 51%,rgba(125,185,232,1) 100%); /* IE10+ */ 
    background: linear-gradient(to bottom, rgba(30,87,153,1) 0%,rgba(41,137,216,1) 50%,rgba(32,124,202,1) 51%,rgba(125,185,232,1) 100%); /* W3C */ 
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#1e5799', endColorstr='#7db9e8',GradientType=0); /* IE6-8 */ 
} 

您可以在這裏攻讀-MS-CSS:http://ie.microsoft.com/TESTDRIVE/Graphics/CSSGradientBackgroundMaker/Default.html

+0

如果我理解正確,我不認爲'-ms-linear-gradient'是必需的,因爲IE 10也支持'linear-gradient'。 –

+0

http://caniuse.com/#search=gradient列出的IE10和IE11支持css漸變你的理解似乎是正確的,它只是不考慮持有人版本的IE瀏覽器。 –

+0

當然。 IE 9根本不支持CSS漸變(除非你計算過濾器)。 –