How do I target only Internet Explorer 10 for certain situations like Internet Explorer-specific CSS or Internet Explorer-specific JavaScript code?

前端 未结 25 2677
谎友^
谎友^ 2020-11-22 06:19

How do I target only Internet Explorer 10 for certain situations like Internet Explorer-specific CSS or Internet Explorer-specific JavaScript code?

I tried this, but

相关标签:
25条回答
  • 2020-11-22 06:43

    Internet Explorer 10 does not attempt to read conditional comments anymore. This means it will treat conditional comments just like any other browser would: as regular HTML comments, meant to be ignored entirely. Looking at the markup given in the question as an example, all browsers including IE10 will ignore the comment portions, highlighted gray, entirely. The HTML5 standard makes no mention of conditional comment syntax, and this is exactly why they have chosen to stop supporting it in IE10.

    Note, however, that conditional compilation in JScript is still supported, as shown in the comments as well as the more recent answers. It's not going away in the final release either, unlike jQuery.browser. And of course, it goes without saying that user-agent sniffing remains as fragile as ever and should never be used under any circumstances.

    If you really must target IE10, either use conditional compilation which may still see support in the near future, or — if you can help it — use a feature detection library such as Modernizr instead of (or in conjunction with) browser detection. Unless your use case requires noscript or accommodating IE10 on the server side, user-agent sniffing is going to be more of a headache than a viable option.

    Sounds pretty cumbersome, but remember that as a modern browser that's highly conformant to today's Web standards1, assuming you've written interoperable code that is highly standards-compliant, you shouldn't have to set aside special code for IE10 unless absolutely necessary, i.e. it's supposed to resemble other browsers in terms of behavior and rendering.2 And it sounds far-fetched, given IE's history, but how many times have you expected Firefox or Chrome to behave the same way only to be met with dismay?

    • Firefox did not support box-sizing unprefixed for years
    • Firefox has historically had weird outline behavior, and this was also the case for years
    • Firefox refuses to behave reasonably when it comes to positioned table-cells, citing undefined behavior as an excuse, while other browsers appear to cope just fine
    • Safari and Chrome have lots of trouble with certain CSS selectors, sometimes with fixes that really take you back to the good ol' days of IE5, IE6 and IE7
    • Chrome seems to have lots of trouble in the repainting department in general, for example not reflowing layouts correctly when media styles are updated; it seems that half of Chrome's bugs can be worked around simply and only by forcing a repaint, again IE5/6/7-level stuff
    • A few strains of WebKit have been known to outright lie about support for certain features, meaning they actually defeat feature detection mechanisms, of all things

    If you do have a legitimate reason to be targeting certain browsers, by all means sniff them out with the other tools given to you. I'm just saying that you're going to be much more hard-pressed to find such a reason today than what it used to be, and it's really just not something you can rely on.


    1 Not only IE10, but IE9, and even IE8 which handles most of the mature CSS2.1 standard far better than Chrome, simply because IE8 was so focused on standards compliance (at which time CSS2.1 was already pretty stable with only minor differences from today's recommendation) while Chrome seems to be little more than a half-polished tech demo of cutting-edge pseudo-standards.

    2 And I may be biased when I say this, but it sure as hell does. If your code works in other browsers but not IE, the odds that it's an issue with your own code rather than IE10 are far better compared to, say, 3 years ago, with previous versions of IE. Again, I may be biased, but let's be honest: aren't you too? Just look at your comments.

    0 讨论(0)
  • 2020-11-22 06:43

    I use this script - it's antiquated, but effective in targeting a separate Internet Explorer 10 style sheet or JavaScript file that is included only if the browser is Internet Explorer 10, the same way you would with conditional comments. No jQuery or other plugin is required.

    <script>
        /*@cc_on
          @if (@_jscript_version == 10)
              document.write(' <link type= "text/css" rel="stylesheet" href="your-ie10-styles.css" />');
          @end
        @*/
    </script >
    
    0 讨论(0)
  • 2020-11-22 06:44

    A good place to start is the IE Standards Support Documentation.

    Here is how to target IE10 in JavaScript:

    if ("onpropertychange" in document && !!window.matchMedia) {
    ...
    }
    

    Here is how to target IE10 in CSS:

    @media all and (-ms-high-contrast: none) {
    ...
    }
    

    In case IE11 needs to be filtered or reset via CSS, see another question: How to write a CSS hack for IE 11?

    0 讨论(0)
  • 2020-11-22 06:45

    I just wanted to add my version of IE detection. It's based on a snippet found at http://james.padolsey.com/javascript/detect-ie-in-js-using-conditional-comments/ and exteded to also support ie10 and ie11. It detects IE 5 to 11.

    All you need to do is add it somewhere and then you can always check with a simple condition. The global var isIE will be undefined if it's not an IE, or otherwise it will be the version number. So you can easily add things like if (isIE && isIE < 10) or alike.

    var isIe = (function(){
        if (!(window.ActiveXObject) && "ActiveXObject" in window) { return 11; /* IE11 */ }
        if (Function('/*@cc_on return /^10/.test(@_jscript_version) @*/')()) { return 10; /* IE10  */ }
        var undef,
            v = 3, div = document.createElement('div'), all = div.getElementsByTagName('i');
        while (
            div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->',
                all[0]
            );
        return v > 4 ? v : undef;
    }());
    
    0 讨论(0)
  • 2020-11-22 06:45

    Here is how I do custom CSS for Internet Explorer:

    In my JavaScript file:

    function isIE () {
          var myNav = navigator.userAgent.toLowerCase();
          return (myNav.indexOf('msie') != -1) ? parseInt(myNav.split('msie')[1]) : false;
    }
    
    jQuery(document).ready(function(){
        if(var_isIE){
                if(var_isIE == 10){
                    jQuery("html").addClass("ie10");
                }
                if(var_isIE == 8){
                    jQuery("html").addClass("ie8");
                    // you can also call here some function to disable things that 
                    //are not supported in IE, or override browser default styles.
                }
            }
        });
    

    And then in my CSS file, y define each different style:

    .ie10 .some-class span{
        .......
    }
    .ie8 .some-class span{
        .......
    }
    
    0 讨论(0)
  • 2020-11-22 06:46

    I found a solution on this site where someone had a valuable comment:

    The solution is:

    if (Function('/*@cc_on return document.documentMode===10@*/')()){
        document.documentElement.className+=' ie10';
    }
    

    It

    • doesn’t need conditional comments;
    • works even if comment stripping compression/processing;
    • no ie10 class added in Internet Explorer 11;
    • more likely to work as intended with Internet Explorer 11 running in Internet Explorer 10 compatibility mode;
    • doesn’t need standalone script tag (can just be added to other JavaScript code in the head).
    • doesn't need jQuery to test
    0 讨论(0)
提交回复
热议问题