欢迎来到[自学php网] ①群 AG亚游集团

AG亚游集团 > 网站前端 > css教程 >

CSS hacker使用小结(兼容IE6、7、8)

来源:未知 ?? 时间:2019-01-04 11:03?作者:小飞侠

[导读] 什么是CSS hack 由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持、解析不一样,导致在不同浏览器的环境中呈现出不一致的页面展现效果。...

什么是CSS hack 

由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持、解析不一样,导致在不同浏览器的环境中呈现出不一致的页面展现效果。这时,我们为了获得统一的页面效果,就需要针对不同的浏览器或不同版本写特定的CSS样式,我们把这个针对不同的浏览器/不同版本写相应的CSS code的过程,叫做CSS hack! 

CSS hack的原理 

由于不同的浏览器和浏览器各版本对CSS的支持及解析结果不一样,以及CSS优先级对浏览器展现效果的影响,我们可以据此针对不同的浏览器情景来应用不同的CSS。

<meta http-equiv="X-UA-Compatible"  content="IE=edge,chrome=1">这行代码是永远以最新的IE版本模式来显示网页,使IE支持HTML5。
<meta name="renderer" content="webkit">这行代码是360浏览器渲染页面需默认用极速内核
<!--[if lt IE 9]>
    <script src="/cdnaff4bootcssaff4com/html5shiv/3.7.2/html5shiv.min.js">
    <script src="/cdnaff4bootcssaff4com/respond.js/1.4.2/respond.min.js">
<![endif]-->


 
建议:使用ietester软件测试IE6、7、8。
顾名思义,!important的优先级要高. 举例说明:
body
{
           background-color:#FF0000 !important;
           *background-color:#00FF00 !important;
           *background-color:#0000FF;
           background-color:#000000;
 }
IE6选择最后一个,即: (因为IE6对important不感冒)
IE7选择第二个,即:background-color:#000000;(因为IE7开始对important感冒了,同时还死守着它对 * 感情的最后一版本,但important并未起到优先级的作用)
IE8和Firefox、Opera、Safari选择第一个,即:!important;(IE8完全感冒于important,同时丢弃了对*的感情)
另外再补充一个,下划线"_",
IE6支持下划线,IE7、IE8和Firefox、Opera、Safari均不支持下划线。

整理二:IE6,IE7,FireFox,Opera,Safari兼容CSS的解决方法及CSS差别

IE6,IE7,FireFox,Opera,Safari兼容CSS的解决方法及CSS差别
参考网址:/9750/webshouce/csshack/


以下两种方法几乎能解决现今所有HACK:

1. !important
随着IE7对!important的支持, !important 方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.)
2. IE6/IE7对FireFox
*+html 与 *html 是IE特有的标签, firefox 暂不支持.而*+html 又为 IE7特有标签.
3.当网页在 IE 中有异常表现时,可以尝试激发 haslayout 来看看是不是问题所在。常用的方法是给某元素 css 设定 zoom:1。使用 zoom:1 是因为大多数情况下,它能在不影响现有环境的条件下激发元素的 haslayout。而一旦问题消失,那基本上就可以判断是haslayout 的原因。然后就可以通过设定相应的 css 属性来对这个问题进行修正了。建议首先要考虑的是设定元素的width/height 属性,其次再考虑其他属性。
对 IE6 及更早版本来说,常用的方法被称为霍莉破解(Holly hack),即设定这个元素的高度为 1%(height:1%;)。需要注意的是,当这个元素的 overflow 属性被设置为 visible 时,这个方法就失效了。或者使用 IE的条件注释。对 IE7 来说,最好的方法是设置元素的最小高度为 0 (min-height:0;)。 
4.ie-css3.htc让IE6, 7, 8也支持CSS3圆角,阴影,文本阴影等效果。

5.在mozilla firefox和IE中的BOX模型解释不一致导致相差2px解决方法:div{margin:30px!important;margin:28px;},注意这两个margin的顺序一定不能写反,据阿捷的说法!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:div{maring:30px;margin:28px;}
重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;
6.设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。解决方案是在这个div里面加上display:inline。
7.min-width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。但IE不认得这个,而它实际上把  width当做最小宽度来使。为了让这一命令在IE上也能用,可以把一个
 放到  标签下,然后为 div指定一个类:

然后CSS这样设计: 

selector{
min-width:600px;
_width:expressio n(document.body.clientWidth < 600?"600px":"auto");
} 
或selector {  
    min-height:500px;  
    height:auto !important;  
    height:500px;  
}


8.ie下元素消失,给该元素添加:position:relative;
9.IE7浏览器下,文字越多,按钮两侧padding留白就越大,解决办法是添加overflow:visible属性。


最新文章

点击排行

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号@版权所有AG亚游集团

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

日本小学引进高价阿玛尼校服 校长向家长道歉 博通高通博弈陷入胶着状态 美国政府介入 NBA史上第2刚猛的状元对决!2个魔术师同场对抡 朝鲜宣布公开废弃核试验场 文在寅:有诚意很欢迎 以色列轰炸叙利亚2小时 美国:坚定支持以色列自卫权 加州“死谷”创最热记录 最高气温达52.7摄氏度 苹果联合创始人被骗走7枚比特币 价值逾7万美元 美国媒体巨头为何对Sky情有独钟? 日经产相表示将在WTO框架下应对美进口限制 苹果抛压沉重 铁矿石不宜追空 慎入!凯恩右脚踝严重扭伤 或将长期缺阵 曝马竞正在观察高拉特 若不与恒大续约或促转会
美军抱怨“联合星”指挥机脆弱 很容易被中俄击落 经济观察网:疫苗事件 怎样才算是明明白白的交代 《区块链100问》第86集:山寨币和竞争币是什么? 乐视网重组计划历时三年终失败 复牌或已进入倒计时 韩国前地方高官被指性侵秘书 检方对相关场所调查 吴敦义朱立伦暗斗?台媒体人:马英九或参选2020 遇“门槛”抬高危机 美国牛肉恐丢失百亿级“蛋糕” 美团滴滴大战:王兴的无边界扩张与程维的十年规划 台军空降演习伞兵降落伞未打开 从400米高空坠落(图) 警务用车也被“贴条”?交警:是正常的执法行为 3月排名:波尔成最年长世界第1 朱雨玲重返榜首 安徽省委组织部原副部长张耀文逝世 享年69岁
比特币迫近“死亡交叉” 策略师看跌至2800美元 跳动吧,心脏!新疗法让心脏细胞“起死回生” 日本相扑大赛涉嫌歧视女性 登台后竟遭撒盐\"驱魔\" 土耳其:美国不再适合担任中东“调解人” 学习小组:领导干部注意 这是合格干部的标配 二季度财报公布 搜狗的下一个增长点在哪里? 人大代表:“神医神药”蒙骗老人 医疗诈骗待整治 阿尔缅-萨尔基相当选亚美尼亚新总统 任期7年 霍金纪梵希与影视不解之缘:这些作品重温大师风采 开什么店比较有市场 适合女性开的十五种店 身无分文怎样白手起家 利润最高的不起眼行业 AG亚游集团