zoukankan      html  css  js  c++  java
  • IE条件语句,IE hack大全

    Conditional comments only work in IE, and are thus excellently suited to give special instructions meant only for IE. They are supported from IE 5 onwards.

    Conditional comments work as follows:

    <!--[if IE 6]>
    Special instructions for IE 6 here
    <![endif]
    -->
    1. Their basic structure is the same as an HTML comment (<!-- -->). Therefore all other browsers will see them as normal comments and will ignore them entirely.
    2. IE, though, has been programmed to recognize the special <!--[if IE]> syntax, resolves the ifand parses the content of the conditional comment as if it were normal page content.
    3. Since conditional comments use the HTML comment structure, they can only be included in HTML files, and not in CSS files. I'd have preferred to put the special styles in the CSS file, but that's impossible. You can also put an entire new <link> tag in the conditional comment referring to an extra style sheet.

    Example

    Below I added a lot of conditional comments that print out messages according to your IE version.

    Note however, that if you use multiple Explorers on one computer, the conditional comments will render as if all these Explorer versions are the highest Explorer version available on your machine (usually Explorer 6.0).

    Test

    Below are a few conditional comments that reveal the IE version you're using.

    According to the conditional comment this is IE
    According to the conditional comment this is IE 7
    According to the conditional comment this is IE lower than 9
    According to the conditional comment this is IE lower or equal to 7
    According to the conditional comment this is IE greater than 6

    Code

    The syntax I use is:

    <p class="accent">
    <!--[if IE]>
    According to the conditional comment this is IE<br />
    <![endif]
    -->
    <!--[if IE 6]>
    According to the conditional comment this is IE 6<br />
    <![endif]
    -->
    <!--[if IE 7]>
    According to the conditional comment this is IE 7<br />
    <![endif]
    -->
    <!--[if IE 8]>
    According to the conditional comment this is IE 8<br />
    <![endif]
    -->
    <!--[if IE 9]>
    According to the conditional comment this is IE 9<br />
    <![endif]
    -->
    <!--[if gte IE 8]>
    According to the conditional comment this is IE 8 or higher<br />
    <![endif]
    -->
    <!--[if lt IE 9]>
    According to the conditional comment this is IE lower than 9<br />
    <![endif]
    -->
    <!--[if lte IE 7]>
    According to the conditional comment this is IE lower or equal to 7<br />
    <![endif]
    -->
    <!--[if gt IE 6]>
    According to the conditional comment this is IE greater than 6<br />
    <![endif]
    -->
    <!--[if !IE]> -->
    According to the conditional comment this is not IE<br />
    <!-- <![endif]-->
    </p>

    Note the special syntax:

    • gt: greater than
    • lte: less than or equal to

    Also note the last one. It has a different syntax, and its contents are shown in all browsers that are not IE:

    <!--[if !IE]> -->

    CSS hack?

    Are conditional comments CSS hacks? Strictly speaking, yes, since they can serve to give special style instructions to some browsers. However, they do not rely on one browser bug to solve another one, as all true CSS hacks do. Besides, they can be used for more than CSS hacks only (though that rarely happens).

    Since conditional comments are not based on a browser hack but on a deliberate feature I believe they are safe to use. Sure, other browsers could implement conditional comments, too (though as yet none have done so), but they're unlikely to react to the specific query <!--[if IE]>.

    I use conditional comments, though sparingly. First I see if I can find a real CSS solution to an Explorer Windows problem. If I can't, though, I don't hesitate to use them.

    Comment tag

    A reader told me IE also supports the (non-standard) <comment> tag.

    <p>This is <comment>not</comment> IE.</p>

    This isIE.

    This tag might be a replacement for the !IE conditional comment.

  • 相关阅读:
    Linux 分卷压缩
    用 virtualenv 创建隔离的 Python 运行环境
    Ubuntu 16.04 安装 Python3.6
    Python 的全局变量
    Git 使用总结
    开源的许可证GPL、LGPL、BSD、Apache 2.0
    Python Unofficial Package Site
    apt-get update 更新 ubuntu时出现Hash sum mismatch的原因及解决方法
    Keep It Simple & Stupid
    Python IDLE 增加清屏功能
  • 原文地址:https://www.cnblogs.com/ahjesus/p/2427213.html
Copyright © 2011-2022 走看看