Heim >Web-Frontend >CSS-Tutorial >Unterschiede in den CSS-Stylesheets zwischen den Browsern Firefox und IE
1 CSS-Stil für Firefox ie6 IE7
Die meisten von ihnen werden jetzt mit !important gehackt. Für ie6- und Firefox-Tests kann es normal angezeigt werden, aber ie7 kann !important korrekt interpretieren, was dazu führt Seite zum Scheitern bringen. Ich habe einen guten Hack für IE7 gefunden, der darin besteht, „*+Html“ zu verwenden. Jetzt sollte es mit IE7 durchsucht werden, und es sollte kein Problem geben.
Schreiben Sie nun ein CSS wie dieses:
#1 { color: #333; } /* Moz */
* html #1 { color: #666 } /* IE6 */
*+html #1 { color: #999; } /* IE7 */
Dann wird die Schriftfarbe als #333 unter Firefox, #666 unter IE6 und #666 unter IE7 angezeigt Die Schriftfarbe wird als #999 angezeigt.
2 Zentrierungsprobleme im CSS-Layout
Die wichtigsten Stildefinitionen lauten wie folgt:
body {TEXT-ALIGN: center;}
#center { MARGIN-RIGHT : auto; MARGIN-LEFT: auto; }
Definieren Sie zuerst TEXT-ALIGN: center im übergeordneten Element Diese Einstellung reicht aus.
Aber es kann nicht in Mozilla zentriert werden. Die Lösung besteht darin, beim Festlegen der Definition des untergeordneten Elements „MARGIN-RIGHT: auto;MARGIN-LEFT: auto;“ hinzuzufügen.
Beachten Sie, dass dies der Fall ist, wenn Sie diese Methode zum Zentrieren der gesamten Seite verwenden möchten Es wird empfohlen, es nicht in ein DIV einzuschließen. Sie können mehrere Divs nacheinander aufteilen, solange Sie MARGIN-RIGHT: auto;MARGIN-LEFT: auto in jedem geteilten Div definieren.
3 Verschiedene Interpretationen des Box-Modells.
#box{
width:600px; //für ie6.0- width:500px;
//für ff+ ie6.0
}
#box{
width:600px!important
//für ff
width:600px;
width /**/:500px;
//für ie6.0-
4 Doppelter Abstand, erzeugt durch Floating ie
#box{ float:left; width:0 0 0 100px; In diesem Fall generiert IE einen Abstand von 200 Pixeln. display:inline; // Die schwebenden Elemente ignorieren🎜>
Dann ist das CSS wie folgt gestaltet:
# Container{
min-width: 600px; width:e Eine minimale Breite ist normal; die Breite in Zeile 2 verwendet jedoch Javascript, das nur vom IE erkannt wird, wodurch auch Ihr HTML erstellt wird Dokument weniger formell. Es implementiert tatsächlich die Mindestbreite durch Javascript-Beurteilung.
.hackbox{
display:table;
//Anzeige des Objekts als Tabelle auf Blockelementebene
clear:both;
}
oder hinzufügen: after (Pseudoobjekt), um den Inhalt festzulegen, der nach dem Objekt auftritt, normalerweise in Verbindung verwendet mit Inhalt, IE Dieses Pseudoobjekt wird nicht unterstützt und wird von Ie-Browsern nicht unterstützt, sodass es keine Auswirkungen auf IE/WIN-Browser hat. Dies ist das problematischste
......#box:after{
content: "."; display: block;
height: 0;
clear : beides;
#box{
float:left;
width:800px;}
#left{
float:left;
width:50%;}
#right{
width:50%;
}
*html #left{
margin-right:-3px;
//Dieser Satz ist der Schlüssel
}
HTML-Code
p[id]{}div[id]{ }
Dies ist für IE6.0 und Versionen darunter ausgeblendet 🎜>
Es gibt immer noch einen Unterschied zwischen Attributselektor und Unterselektor. Der Umfang des Attributselektors ist beispielsweise in p[id ], alle p-Tags mit IDs haben den gleichen Stil.
10 IE-Versteckproblem
Wenn die div-Anwendung komplex ist, gibt es in jeder Spalte einige Links und verbirgt sich -and-seek-Probleme können in DIVs leicht auftreten.
Einige Inhalte können nicht angezeigt werden. Wenn die Maus diesen Bereich auswählt, wird festgestellt, dass sich der Inhalt tatsächlich auf der Seite befindet.Lösung: Verwenden Sie das Attribut „line-height“ für #layout oder verwenden Sie eine feste Höhe und Breite für #layout. Halten Sie die Seitenstruktur so einfach wie möglich.
11 Ungeeignete Höhe
Ungeeignete Höhe bedeutet, dass die Höhe der äußeren Ebene nicht automatisch angepasst werden kann, wenn sich die Höhe des inneren Objekts ändert, insbesondere wenn das innere Objekt
Inhalt im p-Objekt
#box {background-color:#eee; }
#box p {margin-top: 20px; text-align:center; }