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 „ Tabellen gibt es um tabellarische Daten darzustellen. Umgekehrt heißt dies...“
Optionen

Hallo Borlander,
Ich hatte mich heute schon selbst von den Vorteilen von div Programmierung fuer html-Pags ueberzeugt. Ich habe heute den Kopf und die linke Spalte einer Seite umcodiert vom table-Layout zum div-Layout.

http://www.moon-and-sun.com/booking/index-en.php

Alle die kleinen Aergernisse, die ich bei der table-Programmierung als Systemimmanent hingenommen hatte, lassen sich mit div's eliminieren. Da ist zun Beispiel das exakte Einpassen eines Images, das in einen td-Rahmen nie funktioniert. Da ist immer irgendwo ein argerlicher Hintergrundstreifen zu sehen, weil das td sich nicht 100%-ig mit einem Image ausfuellen laesst und fuer Images ist align und valign in tables ein Witz. Das stoerte mich sehr. Auch beim Zoomen eines Images werden die table-Nachbarzellen weggequetsch, bei div wird das zoomende Image ueber die Nachbarcontainer ueberschrieben, wenn man den z-Index geschickt waehlt. Auch Ramen lassen sich exakter setzen und colorieren, ohne doppelte Rahmen von benachbarten Zellen zu bekommen. Es gibt also viele Vorteile mit div gegenueber table. Man braucht nur mal einen Anstoss zum Umsteigen.
Ich danke Dir, mir diesen Anstoss gegeben zu haben.
MfG
Sigi Saudi

Gruesse aus Wang Nam Kiaw / Thailand
bei Antwort benachrichtigen