Homepage selbermachen 7.846 Themen, 35.563 Beiträge

Table-Definition mit Javascript

Sigi Saudi / 7 Antworten / Flachansicht Nickles

Hallo Gemeinde,
Dass es Unterschiede in der Interpretation von html zwischen dem IE und Firefox gibt, wurde schon ausreichend diskutiert. Ich finde es besonders aergerlich, dass der IE standardmaessig weisse table-borders setzt, waehrend der Firefox standardmaessig schwarze table-borders verwendet. Da ich nicht in Trauer bin, aergern mich die schwarzen borders, besonders, wenn sie breiter sind.
Zuerst versuchte ich, dem Problem mit dem Attribut bordercolor="white" (oder #fff) in der table-Definition beizukommen. Das war aber keine Loesung, weil der W3C Markup Validation Service dann folgende Fehlermessage anzeigte:

Line 156, Column 20: there is no attribute "BORDERCOLOR"
<table bordercolor="white" width="504" border="12" cellspacing="0" cellpadding=…

Dann versuchte ich es mit einem style-String in der table-Definition der Art:

style="border-color:white;"

Das funktionierte fuer den Firefox einwandfrei, aber nun zeigte der IE in Falle von breiteren Bordern (border="12"), wie ich sie brauchte, alle 4 Seiten der Border reinweiss an. Standardmaessig zeigt der IE die linke und die obere Border weiss und die rechte und die untere Border grau geshaded an. Das erzeugt einen quasi 3D Eindruck, den ich im IE nicht verlieren wollte.
Also entschloss ich mich, das Problem mit Javascript anzugehen. Meine Loesung ist in keiner Weise html-Konform, aber sie funktioniert. Ich moechte die Loesung hier mal vorstellen und eure (konstruktive) Meinung dazu hoeren.
Ich habe den table nicht mehr im html-Code generiert, sondern anstelle der table-Definition setzte ich folgende Javascript-Zeilen ein:

<script type="text/javascript">
<!-- createtable() -->
</script>

Die dazugehoerige Funktion im head ist:

<script type="text/javascript">
<!--
function createtable()
{
var browserName=navigator.appName;

if (browserName=="Netscape")
{
document.write("<table style='border-color:white;' width='504' border='12' cellspacing='0' cellpadding='0' bgcolor='#66ccff'>");
}
else
{
document.write("<table width='504' border='12' cellspacing='0' cellpadding='0' bgcolor='#66ccff'>");
}
}
-->
</script>

Ich frage also zuerst ab, ob der verwendete Browser ein Netscape (Firefox) Browser ist. Wenn das zutrifft, fuege ich mit einem document.write an der Stelle des Funktionsaufrufs eine table-Definition in den html-Code ein, die den style-String fuer die border-color enthaelt, damit der Firefox nun eine weisse Border, geshaded darstellt. Ist der Browser nicht ein Netscape (gilt natuerlich auch fuer den IE), fuege ich eine table-Definition in den html-Code ein, die den style-String nicht enthaelt.
Diese Prozedur liefert mir das Ergebnis, das ich wuensche. Beide Browser generieren eine weissen Rahmen, geshaded. Beispiel:

http://www.moon-and-sun.com/booking/Lilawadi-ger.html

Natuerlich meckert jetzt der W3C Validator extrem:

Line 172, Column 4: document type does not allow element "TR" here
<tr>
Das kommt fuer jedes tr tag in dem table, da ja im html-code die table-Definition fehlt. Und weiter:

Line 227, Column 8: end tag for element "TABLE" which is not open
</table>

Was meint ihr dazu? Kann man das machen? Das ich mich mit dieser Massnahme extrem ausserhalb der html-Konventionen bewege, weiss ich.
Ich bitte um KONSTRUKTIVE Meinungen und Anregungen und vielleicht auch andere Loesungen, die ich nicht gefunden habe.
MfG
Sigi Saudi aus Wang Nam Kiaw / Thailand


Gruesse aus Wang Nam Kiaw / Thailand
bei Antwort benachrichtigen
Sigi Saudi Borlander „Ich sehe keinen Grund warum man für den Rand mehr als das/die CSS-Attribut e...“
Optionen

Hallo Borlander,
Erst mal recht herzlichen Dank fuer Deine Antwort zu meinem Problem. Die CSS Loesung funktioniert natuerlich wie gewuensch.
Eigentlich weiss man diese Dinge, aber wenn man sie braucht, ist es wie verhext. Da ist man dann darauf fixiert, dass IE und Firefox html unterschiedlich interpretieren und dann ist die "logische" Konsequenz, dass sie unterschiedliche Definitionen brauchen. An andere Moeglichkeiten denkt man dann nicht und deshalb hatte ich den Artikel geschrieben, damit freundliche Leute wie Du mir auf die Spruenge helfen.
Ich generierte nun also folgende Klasse:

.frame
{
border-left:12px solid white;
border-top:12px solid white;
border-right:12px solid grey;
border-bottom:12px solid grey;
}

und die gemeinsame table-Definition fuer alle Browser sieht dann folglich so aus:

<table class="frame" width="504" cellspacing="0" cellpadding="0" bgcolor="#66ccff">

und das Ergebnis ist zu sehen unter

http://www.moon-and-sun.com/booking/FueangFa-ger.html

Vielen Dank noch einmal. Num muss ich bloss noch die anderen html-Files meiner Homepage durchaendern.
MfG
Sigi Saudi aus dem 31.6 Grad warmen Wang Nam Kiaw / Thailand

Gruesse aus Wang Nam Kiaw / Thailand
bei Antwort benachrichtigen