Browserweichen: Unterschied zwischen den Versionen
Yehudi (Diskussion | Beiträge) (→Stern-html-Hack) |
Yehudi (Diskussion | Beiträge) (Baustein entfernt, Autoren, Nav) |
||
(7 dazwischenliegende Versionen von 3 Benutzern werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
− | + | Autoren: [http://www.linux-club.de/faq/Benutzer:Yehudi Yehudi], [http://www.linux-club.de/faq/Benutzer:Djh2 Djh2] | |
+ | |||
+ | |||
+ | == Browserabhängige externe Stylsheets == | ||
+ | Um mit dem dem Netscape Communicator ein anderes Steelsheet zuzuweisen eignet sich folgender Code: | ||
+ | |||
+ | <pre><nowiki><title>Stylesheet für NN 4</title> | ||
+ | <link rel="stylesheet" typ="text/css" | ||
+ | href="standard.css"> | ||
+ | <style typ="text/css"><!- | ||
+ | @import url ("ohne_nn4.css"); | ||
+ | --></style></nowiki></pre> | ||
+ | |||
+ | -(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet) | ||
== Conditional Comments == | == Conditional Comments == | ||
Zeile 36: | Zeile 49: | ||
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet) | -(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet) | ||
+ | |||
+ | == Möglichkeiten mit PHP == | ||
+ | |||
+ | function browsercheck() { | ||
+ | $browser = $_SERVER['HTTP_USER_AGENT']; #liest den Browser des Users aus | ||
+ | if(preg_match("/^(mozilla)(.*)(firefox|ie|Opera|netscape)/i",$browser)) { | ||
+ | |||
+ | /*Kontrolle darauf ob nach Mozilla(was immer am anfang steht) | ||
+ | noch Firefox Internetexplorer Opera oder Netscape steht, | ||
+ | damit man später auch den Mozilla herausfiltern kann, | ||
+ | da dieser Browser keine spezifischen strings hat.*/ | ||
+ | |||
+ | if(preg_match("/(ie)(.*)(\))$/i",$browser)) | ||
+ | return 1; | ||
+ | else | ||
+ | return 2; | ||
+ | } else | ||
+ | return 0; | ||
+ | } | ||
+ | |||
+ | switch(browsercheck()) { | ||
+ | case 1: | ||
+ | #Internet Explorer | ||
+ | echo '<link rel="stylesheet" typ="text/css" href="internetexplorer.css">'; | ||
+ | break; | ||
+ | case 2: | ||
+ | #Mozilla, Mozilla Firefox, Opera, etc. | ||
+ | echo '<link rel="stylesheet" typ="text/css" href="mozilla.css">'; | ||
+ | break; | ||
+ | default: | ||
+ | #Sonstige Browser | ||
+ | echo '<link rel="stylesheet" typ="text/css" href="default.css">'; | ||
+ | } | ||
+ | |||
+ | Wird derzeit beim mir benutzt auf [http://www.criminal-career.com/ www.criminal-career.com]. | ||
+ | Eine ziemlich gute Methode, da das ganze Serverseitig geschieht, also auch mit deaktiviertem JavaScript, etc. funktioniert. | ||
+ | Hinzugefügt von [[Benutzer:Djh2|Djh2]] 19:30, 9. Apr 2007 (CEST) | ||
== Browserweichen mit Selektoren == | == Browserweichen mit Selektoren == | ||
Zeile 54: | Zeile 104: | ||
* html html, body { | * html html, body { | ||
background: #e8e8e8; }</nowiki></pre> | background: #e8e8e8; }</nowiki></pre> | ||
+ | |||
+ | Die Darstellung (als Vergleich) des Internet-Explorer 4 ist hier zu finden: http://www.yehudi.de/internet-explorer-4-os-9.htm | ||
=== Attributselektor === | === Attributselektor === | ||
Zeile 68: | Zeile 120: | ||
=== Stern-html-Hack === | === Stern-html-Hack === | ||
− | Dieses kann | + | Dieses kann eingesetzt werden, um Werte für den Internet-Explorer ab Version 5 anders darzustellen. Auf meiner Seite http://www.engefuerst.de tritt das Problem auf, das im Internet-Explorer 5-6 der Header um zwei Pixel nach links verrutscht war. Da der IE ab Version 5-6 die falsche Aussage * html nicht wie die anderen Browser interpretiert, und die Werte liest, werden die vorrangegangenen Werte überschrieben. |
Das sieht dann an der Stelle so aus: | Das sieht dann an der Stelle so aus: | ||
Zeile 75: | Zeile 127: | ||
<pre><nowiki>#header { | <pre><nowiki>#header { | ||
− | |||
background: url('images/header.jpg') no-repeat; | background: url('images/header.jpg') no-repeat; | ||
padding: 0px; | padding: 0px; | ||
Zeile 104: | Zeile 155: | ||
Im oben benannten ''Universalselektor''ergab sich das Problem, dass der IE auf dem Mac die Seite das Weiß an den Rändern zeigt. Durch die gleich danach folgende Anweisung, wurde die Problematik dort auch behoben. | Im oben benannten ''Universalselektor''ergab sich das Problem, dass der IE auf dem Mac die Seite das Weiß an den Rändern zeigt. Durch die gleich danach folgende Anweisung, wurde die Problematik dort auch behoben. | ||
+ | |||
+ | == einzelne Browserabhängige CSS-Anweisungen == | ||
+ | |||
+ | |||
+ | === Trick mit dem Unterstrich === | ||
+ | |||
+ | |||
+ | === !important als Browserweiche === | ||
+ | |||
+ | Auf http://www.engelfuerst.de setze ich rechts auf der Sidebar runde Ecken ein, diese werden aber von dem Internet Explorer bis Version 6 völlig falsch dargestellt. !important verhindert das überschreiben einer darauffolgenden CSS-Anweisung. Der Internet-Explorer und Netscape 4 kennen diese Regel nicht, und überschreiben mit der nachfolgenden Anweisung den bisherigen Wert. Der Wert none schaltet dann mit einem Schlag die runden Ecken ab, so, dass nun ein vertretbares Aussehen mit eckigen Ecken statt mit runden Ecken zustande kommt. Ab Internet-Explorer 7 werden die runden Ecken korrekt dargestellt, und auch die important-Regel gelesen. | ||
+ | <pre><nowiki>.rtop *, .rbottom *{ | ||
+ | display: block !important; | ||
+ | display: none; | ||
+ | height: 1px; | ||
+ | overflow: hidden, | ||
+ | background:#e7e7e7; | ||
+ | padding-left: 22px; | ||
+ | margin-left: 521px; | ||
+ | width: 240px; | ||
+ | }</nowiki></pre> | ||
== Links == | == Links == | ||
Zeile 112: | Zeile 183: | ||
* http://www.webkrauts.de/2004/12/18/conditional-comments-fuer-den-internet-explorer/ | * http://www.webkrauts.de/2004/12/18/conditional-comments-fuer-den-internet-explorer/ | ||
* http://www.aboutwebdesign.de/awd/content/1004214286.shtml | * http://www.aboutwebdesign.de/awd/content/1004214286.shtml | ||
+ | |||
+ | ---- | ||
+ | |||
+ | [[Webdesign|zum Webdesign]] | ||
[[Category:Webdesign]] | [[Category:Webdesign]] |
Aktuelle Version vom 9. April 2007, 18:15 Uhr
Inhaltsverzeichnis
Browserabhängige externe Stylsheets
Um mit dem dem Netscape Communicator ein anderes Steelsheet zuzuweisen eignet sich folgender Code:
<title>Stylesheet für NN 4</title> <link rel="stylesheet" typ="text/css" href="standard.css"> <style typ="text/css"><!- @import url ("ohne_nn4.css"); --></style>
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet)
Conditional Comments
Conditional Comments werden nur vom Internetexplorer in verschiedenen Versionen erkannt:
<!--[if IE 5]> Dort gehört der code für den IE rein <![endif]-->
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet)
Boxmodell-Hack
Der Boxmodell Hack ist auch nur dafür da, um fehlerhafte Darstellungen im Internet-Explorer bis Version 5.5 zu umgehen.
.content { CSS-Anweisung; voice-family: "\"}\""; voice-family: inherit; CSS-Anweisung; }
Bis zum IE 5.5 wird die untere Anweisung nicht gelesen, ursprünglich wurde er erfunden, um unkorrekte Darstellung der Weite im IE bis 5.5 zu korrigieren, der Hack ist aber auch für andere Anweisungen brauchbar.
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet)
Deutsche Version
Original Version
Möglichkeiten mit Java-Script
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet)
Möglichkeiten mit PHP
function browsercheck() { $browser = $_SERVER['HTTP_USER_AGENT']; #liest den Browser des Users aus if(preg_match("/^(mozilla)(.*)(firefox|ie|Opera|netscape)/i",$browser)) { /*Kontrolle darauf ob nach Mozilla(was immer am anfang steht) noch Firefox Internetexplorer Opera oder Netscape steht, damit man später auch den Mozilla herausfiltern kann, da dieser Browser keine spezifischen strings hat.*/ if(preg_match("/(ie)(.*)(\))$/i",$browser)) return 1; else return 2; } else return 0; } switch(browsercheck()) { case 1: #Internet Explorer echo '<link rel="stylesheet" typ="text/css" href="internetexplorer.css">'; break; case 2: #Mozilla, Mozilla Firefox, Opera, etc. echo '<link rel="stylesheet" typ="text/css" href="mozilla.css">'; break; default: #Sonstige Browser echo '<link rel="stylesheet" typ="text/css" href="default.css">'; }
Wird derzeit beim mir benutzt auf www.criminal-career.com. Eine ziemlich gute Methode, da das ganze Serverseitig geschieht, also auch mit deaktiviertem JavaScript, etc. funktioniert. Hinzugefügt von Djh2 19:30, 9. Apr 2007 (CEST)
Browserweichen mit Selektoren
Universalselektor
Im Internet-Explorer 4 wird das Hintergrund-Image auf http://www.yehudi.de nicht geladen, aber die Farbe, die für die Seite verantwortlich ist, dadurch wird die ganze Seite grau, und der Seitenrand rechts hebt sich nicht mehr ab. Hier hilft folgender Hack:
html, body { height: auto; background: url(images/snap_ground.png) top center repeat-y #e8e8e8; text-align: center; } * html, body { background: #ffffff; } * html html, body { background: #e8e8e8; }
Die Darstellung (als Vergleich) des Internet-Explorer 4 ist hier zu finden: http://www.yehudi.de/internet-explorer-4-os-9.htm
Attributselektor
Der Internet-Explorer (bis 6 zumindest) und Netscape 4 können die zweite CSS-Anweisung nicht lesen.
a[href]{ css-Anweisung} a[href]{ css-Anweisung}
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet)
Stern-html-Hack
Dieses kann eingesetzt werden, um Werte für den Internet-Explorer ab Version 5 anders darzustellen. Auf meiner Seite http://www.engefuerst.de tritt das Problem auf, das im Internet-Explorer 5-6 der Header um zwei Pixel nach links verrutscht war. Da der IE ab Version 5-6 die falsche Aussage * html nicht wie die anderen Browser interpretiert, und die Werte liest, werden die vorrangegangenen Werte überschrieben.
Das sieht dann an der Stelle so aus:
#header { background: url('images/header.jpg') no-repeat; padding: 0px; margin-left: 2px; width: 804px; height: 176px; } *html #header { margin-left: 4px; }
Stern-Kind-Selektor-html-Hack
-(Dieser Hack befindet sich derzeit bei mir nicht im praktischen Einsatz, und ist von mir nicht getestet)
Komentar-Hacks
CSS-Anweisung für den Internet-Explorer 5 am Mac
* html, body { background: #ffffff; /*\*//*/ background: #e8e8e8; /**/ }
Im oben benannten Universalselektorergab sich das Problem, dass der IE auf dem Mac die Seite das Weiß an den Rändern zeigt. Durch die gleich danach folgende Anweisung, wurde die Problematik dort auch behoben.
einzelne Browserabhängige CSS-Anweisungen
Trick mit dem Unterstrich
!important als Browserweiche
Auf http://www.engelfuerst.de setze ich rechts auf der Sidebar runde Ecken ein, diese werden aber von dem Internet Explorer bis Version 6 völlig falsch dargestellt. !important verhindert das überschreiben einer darauffolgenden CSS-Anweisung. Der Internet-Explorer und Netscape 4 kennen diese Regel nicht, und überschreiben mit der nachfolgenden Anweisung den bisherigen Wert. Der Wert none schaltet dann mit einem Schlag die runden Ecken ab, so, dass nun ein vertretbares Aussehen mit eckigen Ecken statt mit runden Ecken zustande kommt. Ab Internet-Explorer 7 werden die runden Ecken korrekt dargestellt, und auch die important-Regel gelesen.
.rtop *, .rbottom *{ display: block !important; display: none; height: 1px; overflow: hidden, background:#e7e7e7; padding-left: 22px; margin-left: 521px; width: 240px; }
Links
- http://www.drweb.de/html/conditional_comments.shtml
- http://www.drweb.de/trickkiste/tricks76.shtml
- http://www.css4you.de/wsbw/index.html
- http://aktuell.de.selfhtml.org/artikel/css/browserweiche/
- http://www.webkrauts.de/2004/12/18/conditional-comments-fuer-den-internet-explorer/
- http://www.aboutwebdesign.de/awd/content/1004214286.shtml