CSS with if/then browser logic

前端 未结 7 1163
清酒与你
清酒与你 2021-01-05 19:37

For browsers < IE7, I want to use a certain style attribute, while for other browsers I\'d like to use another. Can I do this using a single css file, or do I have to do

相关标签:
7条回答
  • 2021-01-05 20:02

    You can use CSS Expressions to some extent.

    See http://gadgetopia.com/post/2774 for some examples. These don't get around conditional CSS attributes per se, but they do allow you to dynamically vary the values of CSS attributes.

    0 讨论(0)
  • 2021-01-05 20:04

    The following page will show you 6 CSS hacks specifically for IE7. You shouldn't use them, but they're the easiest way for getting the exact right look for your website.

    0 讨论(0)
  • 2021-01-05 20:08

    Here's an example how you can include an IE6-specific CSS to override specific CSS classes for IE 6 or lower:

    <link rel="stylesheet" type="text/css" href="/css/screen.css" title="MySiteStyle" media="screen" />
    <!--[if lte IE 6]>
    <link rel="stylesheet" type="text/css" href="/css/screen-ie6.css" title="MySiteStyle" media="screen" />
    <![endif]--> 
    

    Alternatively, you can do it on per-element basis like this:

    <!--[if (!IE) | (gt IE 6)]>
    <div class="header">
    <![endif]--> 
    <!--[if lte IE 6]>
    <div class="ie6_header">
    <![endif]--> 
    

    MSDN has some more details about IE Conditional Comments support.

    0 讨论(0)
  • 2021-01-05 20:09

    You could use CSS hacks. But you shouldn't.

    0 讨论(0)
  • 2021-01-05 20:16

    Well you could use javascript to detect the browser and apply a class based on that. For example, see:

    JQuery Attributes

    0 讨论(0)
  • 2021-01-05 20:28

    You could use conditional comments:

    <!--[if lt IE 7]>
      <style>
        /*your style for IE <=6*/
      </style>
    <![endif]-->
    
    <![if !IE | (gte IE 7)]>
      <style>
        /*your style for other browsers*/
      </style>
    <![endif]>
    

    I've found it to be the cleanest solution for this kind of thing.

    0 讨论(0)
提交回复
热议问题