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
Borlander Sigi Saudi „Hallo Borlander, Ich habe Deinen Rat befolgt und die ganze Seite statt mit...“
Optionen
Warum soll man tables nicht mehr verwenden? Das Ergebnis ist doch gleich. Was ist der Vorteil, Seiten mit div-Containern statt mit tables zu generieren? Ich stelle die Frage ganz ohne Polemik.
Tabellen gibt es um tabellarische Daten darzustellen. Umgekehrt heißt dies jedoch auch, dass in Tabellen erwartet wird, dass dort tabellarische Daten drin sind. Ist also eine Frage der Semantik. Dass es überhaupt in Mode kam Tabellen für Layout-Zwecke nur weil HTML ganz am Anfang früher (als es CSS noch nicht gab) keine anderen Möglichkeiten gab zu komplexere Layouts umzusetzen. Semantische Korrektheit ist u.A. auch wichtig um eine gute Erfassbarkeit für Suchmaschinen zu ermöglichen...

DIVs und SPANs sind Elemente ohne semantische Bedeutung. Wenn es semantisch passende Elemente gibt sind die natürlich zu bevorzugen.

float-Layouts sind übrigens immer ein wenig schwierig...


Gruß
Borlander
bei Antwort benachrichtigen