Heim >Web-Frontend >HTML-Tutorial >Eine vollständige Liste mit Tipps, um Div-CSS mit allen Browsern kompatibel zu machen
CSS技巧
1.div的垂直居中问题 vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行?
2. margin加倍的问题?设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。解决方案是在这个div里面加上display:inline;?例如:?<#div id=”imfloat”>?相应的css为?#IamFloat{?float:left;?margin:5px;/*IE下理解为10px*/?display:inline;/*IE下再理解为5px*/}?
3.浮动ie产生的双倍距离?#box{ float:left; width:100px; margin:0 0 0 100px; //这种情况之下IE会产生200px的距离 display:inline; //使浮动忽略}?这里细说一下block与inline两个元素:block元素的特点是,总是在新行上开始,高度,宽度,行高,边距都可以控制(块元素);Inline元素的特点是,和其他元素在同一行上,不可控制(内嵌元素);?#box{ display:block; //可以为内嵌元素模拟为块元素 display:inline; //实现同一行排列的效果 diplay:table;?
4 IE与宽度和高度的问题 IE 不认得min-这个定义,但实际上它把正常的width和height当作有min的情况来使。这样问题就大了,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用min-width和min-height的话,IE下面根本等于没有设置宽度和高度。?比如要设置背景图片,这个宽度是比较重要的。要解决这个问题,可以这样:?#box{ width: 80px; height: 35px;}html>body #box{ width: auto; height: auto; min-width: 80px; min-height: 35px;}?
5.页面的最小宽度?min -width是个非常方便的CSS命令,它可以指定元素最小也不能小于某个宽度,这样就能保证排版一直正确。但IE不认得这个,而它实际上把width当做最小宽度来使。为了让这一命令在IE上也能用,可以把一个
6.DIV浮动IE文本产生3象素的bug?左边对象浮动,右边采用外补丁的左边距来定位,右边对象内的文本会离左边有3px的间距.?#box{ float:left; width:800px;}?#left{ float:left; width:50%;}?#right{ width:50%;}?*html #left{ margin-right:-3px; //这句是关键}?
7.IE捉迷藏的问题?当div应用复杂的时候每个栏中又有一些链接,DIV等这个时候容易发生捉迷藏的问题。?有些内容显示不出来,当鼠标选择这个区域是发现内容确实在页面。 解决办法:对#layout使用line-height属性 或者给#layout使用固定高和宽。页面结构尽量简单。?
8.float的div闭合;清除浮动;自适应高度;?
① 例如:<#div id=”floatA” ><#div id=”floatB” ><#div id=” NOTfloatC” >这里的NOTfloatC并不希望继续平移,而是希望往下排。(其中floatA、floatB的属性已经设置为 float:left;)?这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。在 <#div class=”floatB”> <#div class=”NOTfloatC”>之间加上 < #div class=”clear”>这个div一定要注意位置,而且必须与两个具有float属性的div同级,之间不能存在嵌套关系,否则会产生异常。 并且将clear这种样式定义为为如下即可: .clear{ clear:both;}?
②作为外部 wrapper 的 div 不要定死高度,为了让高度能自动适应,要在wrapper里面加上overflow:hidden; 当包含float的 box的时候,高度自动适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。?例如某一个wrapper如下定义:?.colwrapper{ overflow:hidden; zoom:1; margin:5px auto;}?
③对于排版,我们用得最多的css描述可能就是float:left.有的时候我们需要在n栏的float div后面做一个统一的背景,譬如:?
④万能float 闭合(非常重要!)?关于 clear float 的原理可参见 [How To Clear Floats Without Structural Markup],将以下代码加入Global CSS 中,给需要闭合的div加上class="clearfix" 即可,屡试不爽.?/* Clear Fix */?.clearfix:after { content:"."; display:block; height:0; clear:both; visibility:hidden; }?.clearfix { display:inline-block; }?/* Hide from IE Mac */?.clearfix {display:block;}?/* End hide from IE Mac */?/* end of clearfix */?或者这样设置:.hackbox{ display:table; //将对象作为块元素级的表格显示}?
11.高度不适应?高度不适应是当内层对象的高度发生变化时外层高度不能自动进行调节,特别是当内层对象使用margin 或paddign 时。?例:?#box {background-color:#eee; }?#box p {margin-top: 20px;margin-bottom: 20px; text-align:center; }?
p对象中的内容
?
12. Warum gibt es Lücken unter den Bildern unter IE6? Es gibt viele Möglichkeiten, diesen Fehler zu beheben, oder das Bild auf display:block zu setzen oder legen Sie das Vertical-Alignment-Attribut fest.
So richten Sie Text und Texteingabefeld vertikal aus. align:middle;
14. Gibt es einen Unterschied zwischen ID und Klasse, die in Webstandards definiert sind? 1. Doppelte IDs sind in Webstandards nicht zulässig „aa“? Zweimaliges Wiederholen ist nicht zulässig, und die Klasse definiert eine Klasse, die theoretisch unendlich oft wiederholt werden kann, sodass Definitionen, die mehrere Referenzen erfordern, eine höhere Priorität haben als die Klasse Beispiel 3 oben. Es ist praktisch für JS. Wenn Sie auf ein Objekt auf der Seite warten möchten, können Sie eine ID dafür definieren. Andernfalls können Sie es nur finden, indem Sie die Seitenelemente durchlaufen und angeben Spezifische Attribute. Dies ist eine relativ große Zeit- und Ressourcenverschwendung als eine ID.
15. Die Methode, den Inhalt in LI mit Ellipsen anzuzeigen, überschreitet die Länge Methode ist für IE- und OP-Browser geeignet
16. Warum kann IE die Farbe der Bildlaufleiste in Webstandards nicht festlegen? Die Lösung besteht darin, den Text durch html ?
FF und IE? 1. Problem mit der Div-Zentrierung? Das Div ist bereits zentriert, wenn „margin-left“ und „margin-right“ auf „Auto“ eingestellt sind. IE muss den Text-Algin zuerst im übergeordneten Element zentrieren bedeutet, dass der Inhalt innerhalb des übergeordneten Elements zentriert ist. ? 2. Der Rand und der Hintergrund des Links (ein Tag)? Der Link fügt eine Rand- und Hintergrundfarbe hinzu um sicherzustellen, dass es keine Zeilenumbrüche gibt. Bezogen auf die Menüleiste dient das Festlegen der Höhe von a und der Menüleiste dazu, eine Verschiebung der Anzeige am unteren Rand zu vermeiden. Wenn die Höhe nicht festgelegt ist, kann ein Leerzeichen in die Menüleiste eingefügt werden. 3. Das Problem, dass der Hover-Stil nicht angezeigt wird, nachdem der Hyperlink angeklickt und aufgerufen wurde, sollte bei vielen Leuten aufgetreten sein Die Lösung besteht darin, die Reihenfolge der CSS-Eigenschaften zu ändern: L-V-H-A Code:
13.为什么IE6下容器的宽度和FF解释不同呢
? ?????
Die dritte Methode ist der CSS-Filter, der folgende sind Klassiker, die von ausländischen Websites übersetzt wurden. .?Erstellen Sie einen neuen CSS-Stil wie folgt:?#item {?width: 200px;?height: 200px;?background: red;?}?Erstellen Sie ein neues Div und verwenden Sie den zuvor definierten CSS-Stil:?