Diagonal Gradient in IE

后端 未结 3 1327
天涯浪人
天涯浪人 2020-12-14 04:12

Is there a way to have a diagonal gradient in IE? In Chrome I could do something like this:

body{
    background-image:-webkit-gradient(
    linear,
    left         


        
相关标签:
3条回答
  • 2020-12-14 04:34

    The short answer is, unfortunately, no, you can't. Microsoft's gradient filter is binary - only left to right or top to bottom.

    You might, however, be able to use CSS3 PIE to do what you want. Keep in mind that PIE's support for gradients in IE9 is somewhat sketchy, though, and may or may not work, even if IE7 and 8 do (see their forums for some more info).

    0 讨论(0)
  • 2020-12-14 04:42

    Yes, it is possible! Although it does not work as well as a real diagonal gradient in other browswers.

    There are two important aspects of this solution that make it work:

    • Two divs with the same position and different z-index values (one on top of/in front of the other) and different gradient directions (one horizontal, one vertical)
    • Transparent/translucent colors in gradients (you can read about this in CSS3 Transparency + Gradient)

    Simply place the div with the vertical gradient behind the div with the horizontal gradient (or vice-versa, it doesn't really matter), and make sure the coloring of the topmost gradient is not opaque.

    The result looks like this (Internet Explorer 8):

    several rows of divs (purple vertical backdrop, alternating red/blue horizontal forground) Larger sample

    And the CSS:

    //left sample
    .back
    {
        filter: progid:DXImageTransform.Microsoft.gradient(GradientType="0", startColorstr='#880088', endColorstr='#110011');
        z-index:0;
    }
    
    .front
    {
        filter: progid:DXImageTransform.Microsoft.gradient(GradientType="1", startColorstr='#55ffa885', endColorstr='#55330000');
        z-index:1;
    }
    
    //right sample
    .diaggradientback
    {
        position:absolute;
        left:0;
        top:0;
        width:100%;
        height:100%;
        overflow:hidden;
        filter: progid:DXImageTransform.Microsoft.gradient(GradientType='1', startColorstr='#ffa885', endColorstr='#330000');
    }
    
    .diaggradientfront
    {
        position:absolute;
        left:0;
        top:0;
        width:100%;
        height:100%;
        overflow:hidden;
        filter: progid:DXImageTransform.Microsoft.gradient(GradientType='0', startColorstr='#bbffa885', endColorstr='#bb330000');
    }
    

    Update:

    The documention on this filter does say that multiple filters may be applied together. However, as it turns out, applying more than one gradient filter results in only the last one being applied, so simply applying both filters to one layer doesn't work, and two layers are necessary.

    0 讨论(0)
  • 2020-12-14 04:45

    I found these interesting articles, perhaps if you read them and puzzle a bit with them you might succeed :)

    1. http://www.useragentman.com/blog/csssandpaper-a-css3-javascript-library/
    2. http://www.useragentman.com/blog/2010/03/09/cross-browser-css-transforms-even-in-ie/
    3. http://weston.ruter.net/projects/css-gradients-via-canvas/
    0 讨论(0)
提交回复
热议问题