当前位置: 首页 > 网络学院 > 网页制作基础教程 > WEB设计综合 > 为不同的浏览器载入不同CSS的二种方法

WEB设计综合
使Flash页面通过校验
WEB 标准剖析
制作网页中的渐变背景
表格特效代码全集
Photoshop 打造金属指环
网页标准中链接属性 rel 与 target
HTML在线编辑器的调用及使用方法
div+css设计网页时浮动问题的解决方法
解决XHTML+CSS2.0式的页面结构在IE5和IE5.5下的BUG
WAP 开发出现的中文显示问题
详细的IMG,IFRAME的属性参考
可通过XHTML1.0校验的Flash嵌入代码
在IE和FIREfOX下正常显示的网页内嵌播放器代码
使 XHTML Strict 支持 target 标签
语言(文化)代码与国家地区对照表
网站设计技术规范
点击连接时不出现虚边框的方法
制作1px边框表格的几种方法
图片横向连续滚动的代码
合理架构css

WEB设计综合 中的 为不同的浏览器载入不同CSS的二种方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-03-01   浏览: 1299 ::
收藏到网摘: n/a

由于各浏览器(IE、gecko、opera......)对CSS的渲染方式都有所不同,造成显示效果不同,所以可通过对其载入不同CSS的方法来解决,下面介绍下二种方法来实现,不一定很实用,难的玩一把。

  纯CSS方式

以下是引用片段:
Code
.box{
width: 20em;
height:20em;
background: #369;
}
/*--gecko内核--*/
@media all and (min-width: 0px){
box{
background: #CC0000;
}
}
/*--opera hacks--*/
/*--不能通过W3C CSS检验--*/
<!--[if IE ]><style>
.box{    background: #808080;
}
</style><![endif]-->

  以上代码运行的结果,在IE中是灰色,Opera中是紫红,Firefox中是蓝色

  在IE7以前版本还可采用CSS2的属性选择符来区别,不幸的是IE7开始已能识别。

  本文章由forestgan于15-Oct-2006发表

  javascript的方法

以下是引用片段:
var css_browser_selector = function() {
var
ua = navigator.userAgent.toLowerCase(),
is = function(t){ return ua.indexOf(t) != -1; },
h = document.getElementsByTagName('html')[0],
b = (!(/opera|webtv/i.test(ua)) && /msie (d)/.test(ua)) ? ((is('mac') ? 'ieMac ' : '') + 'ie ie' + RegExp.$1)
: is('gecko/') ? 'gecko' : is('opera') ? 'opera' : is('konqueror') ? 'konqueror' : is('applewebkit/') ? 'webkit safari' : is('mozilla/') ? 'gecko' : '',
os = (is('x11') || is('linux')) ? ' linux' : is('mac') ? ' mac' : is('win') ? ' win' : '';
var c = b+os+' js';
h.className += h.className?' '+c:c;
}();

  此脚本能区别更多的浏览器,具体使用方法可看脚本原作者网站。代码如下:

<!--[if IE]>

<style>
@import url("/tutorials/demo/css/ie.css");
</style>

<![endif]-->

<style type="text/css">
<!--
p{
padding: 1em;
color: #FFF;
text-align: center;
}
h3{
fon-size: 1.5em;
}
.box{
width: 20em;
height:20em;
background: #369;
margin: 2em auto;
}
@media all and (min-width: 0px){
box{
background: #C00;
}
}
-->
</style>

<!--[if IE ]>
<style>
.box{
background: #808080;
}
</style>
<![endif]-->

CSS Browser Selector
<div class="box">
<p>IE中是灰色</p>
<p>Opera中是紫红</p>
<p>Firefox中是蓝色</p>
</div>

如果不能正常显示,请刷新页面。

 

 

评论 (0) All

登陆 | 还没注册?