什么是 CSSHack 技术?

2021-03-04 09:12发布

13条回答
梵梵
2楼 · 2021-03-04 09:35

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的。



小王霸
3楼 · 2021-03-04 09:36

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号,以达到应用不同的CSS样式的目的。

小磊子
4楼 · 2021-03-04 09:39

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的。

例如

1、margin属性在ie6中显示的距离会比其他浏览器中显示的距离宽2倍,也就是说margin-left:20px;在ie6中距左侧对象的实际显示距离是40px,而在非ie6中显示的距左侧对象的距离是设置的值20px;所以要想设置一个对象距离左侧对象的距离在所有浏览器中都显示是20px的宽度的样式应为:.kwstu{margin-left:20px;_margin-left:20px;}

2、kwstu{background:green;/*forfirefox*/width:300px;_width:200px;},一般浏览器会先给元素使用width:300px;的样式,紧接着后面还有个_width:200px;由于下划线_width只有IE6可以识别,所以此样式在IE6中实际设置对象的宽度为200px,后面的把前面的给覆盖了,而其他浏览器不识别_width不会执行_width:200px;这句样式,所以在其他浏览器中设置对象的宽度就是300px。

3、比如要分辨IE6和firefox两种浏览器,可以这样写:

div { background:green;/*forfirefox*/ *background:red;/*forIE6*/(bothIE6&&IE7) }

我在IE6中看到是红色的,在firefox中看到是绿色的。


lucky璐呀
5楼 · 2021-03-04 09:59

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号,以达到应用不同的CSS样式的目的。

什么是 CSSHack 技术?

  • 不同的浏览器对CSS的解析结果是不同的,因此会导致相同的CSS输出的页面效果不同,这就需要CSS Hack来解决浏览器局部的兼容性问题。

  • 而这个针对不同的浏览器写不同的CSS 代码的过程,就叫CSS Hack。

  • CSS属性Hack、CSS选择符Hack以及IE条件注释Hack


buzuofa100
7楼 · 2021-03-04 10:45

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的。

三岁奶猫
8楼 · 2021-03-04 13:39

CSS hack 是CSS中的一种作弊手段,因为目前所有浏览器并没有统一对CSS的支持,例如同样是一个margin:1px,可能在不同的浏览器中出现的效果就一定是1px

在这种情况下,我们只能借助于CSS hack来暂时过渡这个阶段,CSS hack就比如是IE能认出的CSS语句,而FF不能认出,这样就能达到我们的目的了,css hack在很多高级的技巧中出现,不过并不是很推荐使用,毕竟未来的css趋势还不是很明了,尽量避免吧

因为很多css错位问题其实并不是浏览器的错误,而是我们本身的编辑出现的错误。

帅帅马
9楼 · 2021-03-04 14:22

CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不同的CSS样式的目的。

例如

1、margin属性在ie6中显示的距离会比其他浏览器中显示的距离宽2倍,也就是说margin-left:20px;在ie6中距左侧对象的实际显示距离是40px,而在非ie6中显示的距左侧对象的距离是设置的值20px;所以要想设置一个对象距离左侧对象的距离在所有浏览器中都显示是20px的宽度的样式应为:.kwstu{margin-left:20px;_margin-left:20px;}

2、kwstu{background:green;/*forfirefox*/width:300px;_width:200px;},一般浏览器会先给元素使用width:300px;的样式,紧接着后面还有个_width:200px;由于下划线_width只有IE6可以识别,所以此样式在IE6中实际设置对象的宽度为200px,后面的把前面的给覆盖了,而其他浏览器不识别_width不会执行_width:200px;这句样式,所以在其他浏览器中设置对象的宽度就是300px。

3、比如要分辨IE6和firefox两种浏览器,可以这样写:

div { background:green;/*forfirefox*/ *background:red;/*forIE6*/(bothIE6&&IE7) }

我在IE6中看到是红色的,在firefox中看到是绿色的。