12

有没有办法为特定浏览器加载不同的 CSS 文件?

像(糟糕的伪代码):

if firefox
<link rel="stylesheet" type="text/css" href="includes/MyCssFirefox.css" />
if chrome
<link rel="stylesheet" type="text/css" href="includes/MyCssChrome.css" />
if Safari
<link rel="stylesheet" type="text/css" href="includes/MyCssSafari.css" />
4

3 回答 3

22

您想要的理想解决方案不存在:

不幸的是,如果您尝试在 HTML 本身上执行此操作,则不存在跨浏览器解决方案。但是,它适用于大多数版本的 IE。像这样:

<!--[if IE]>
<link rel="stylesheet" type="text/css" href="includes/myIEGeneralStyle.css" />
<![endif]-->
<!--[if IE 6]>
<link rel="stylesheet" type="text/css" href="includes/myIE6Style.css" />
<![endif]-->
<!--[if IE 7]>
<link rel="stylesheet" type="text/css" href="includes/myIE7Style.css" />
<![endif]-->
<!--[if IE 8]>
<link rel="stylesheet" type="text/css" href="includes/myIE8Style.css" />
<![endif]-->

所以最好的解决方案:

像这样的 Javascript 解决方案怎么样:浏览器检测。阅读有关此类的一些信息以更好地阐明,该文件基本上在做的只是这样的概念:

var browser = navigator.userAgent.toLowerCase().indexOf('chrome') > -1 ? 'chrome' : 'other';

显然,它不仅仅是检测浏览器的类型。事实上,它知道版本、操作系统以及您可以在该链接中阅读的更多详细信息。但是,它确实通过将 'chrome' 替换为 'mozilla'、'explorer' 等来检查所有类型的浏览器......

然后添加您的 css 文件,只需跟进条件语句,如下所示:

if (BrowserDetect.browser.indexOf("chrome")>-1) {
document.write('<'+'link rel="stylesheet" href="../component/chromeCSSStyles.css" />');
} else if (BrowserDetect.browser.indexOf("mozilla")>-1) {
    document.write('<'+'link rel="stylesheet" href="../component/mozillaStyles.css" />');
} else if (BrowserDetect.browser.indexOf("explorer")>-1) {
    document.write('<'+'link rel="stylesheet" href="../component/explorerStyles.css" />');
}

祝你好运,希望这能帮到你!

于 2013-01-09T02:49:03.217 回答
0

您可以在服务器端执行此操作。

if(Request.UserAgent is chrome){        
    //here output chrome stylesheet
}
于 2013-01-09T03:04:53.663 回答
0

您可以使用条件注释来定位 IE 浏览器。看看这个:http ://css-tricks.com/how-to-create-an-ie-only-stylesheet/ 。要定位 Firefox,您可以查看以下答案:https ://stackoverflow.com/a/953491/1941910 。但我认为没有必要针对 firefox、chrome 或 safari,它们在应用 CSS 方面都做得很好。

于 2013-01-09T02:50:46.277 回答