• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

[CSS / PHP] Jede zweite Zeile anders, aber aus einer CSS-Datei

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
Ich mache mittels PHP jede zweite Tabellenzeile anders.
[src=php]$color = (++$i % 2) ? '#a9c3e3' : '#a1c8f9';[/src]

Ich würde den Farbwert aber gerne aus einer CSS-Datei beziehen, wo ich eine entsprechende Klasse angelegt habe. Wie bekomme ich den Code entsprechend umgebaut? Irgendwie habe ich das nicht hinbekommen, auch mit PHP schließen und dann dazwischen (als HTML) class="bg1" schreiben hilft nicht, gibt nur einen unschönen Fehler.
 

Kugelfisch

Nerd

Registriert
12 Juli 2013
Beiträge
2.342
Ort
Im Ozean
In welchem Kontext gibst du [kw]$color[/kw] aus? Mutmasslich suchst du
PHP:
$color = (++$i % 2) ? 'bg1' : 'bg2';
echo '<tr class="'.$color.'"><td>....</td></tr>';
Wenn du auf die abwechselnde Färbung in veralteten IE-Versionen, welche CSS Selectors Level 3 nicht unterstützen, verzichten kannst, könntest du das auch ohne PHP in purem CSS lösen:
[src=css]table tr td {
background: #333333;
}
table tr:nth-child(odd) td {
background: #232323;
}[/src]
 

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
  • Thread Starter Thread Starter
  • #3
Danke Kugelfisch,

das Problem ist, dass diese Farbgebung jetzt überall gilt, es aber (schon einige) Ausnahmen gibt und ich es daher "manuell" festlegen will. Gibt es andere Möglichkeiten?
 

Kugelfisch

Nerd

Registriert
12 Juli 2013
Beiträge
2.342
Ort
Im Ozean
Du kannst den Selektor natürlich anpassen, damit er nicht generell für alle table-Elemente, sondern z.B. nur für table-Elemente mit einer bestimmten Klasse gilt, etwa [kw]table.foobar tr td[/kw]
 

Coca-Cola

2. schwarzes KKK Mitglied

Registriert
13 Aug. 2013
Beiträge
69
Ort
.de/BW
Das geht mit auch mit ein paar Zeilen jQuery recht einfach:

[src=javascript]
$(document).ready(function() {
$('#tabelle tr:odd').addClass("odd");
$('#tabelle tr:even').addClass("even");
});
[/src]

Die Tabelle, die bunt werden soll, gibst du die ID Tabelle und den CSS-Klassen odd und even kannst du deine gewünschten Farben geben.
 

LemonDrops

Neu angemeldet

Registriert
20 Juli 2013
Beiträge
543
Höher, schneller weiter ohne jQuery: Einfach ausführen, wenn das DOM fertig ist.

Zum Angucken: http://jsfiddle.net/7VwBP/

[src=javascript]
(function () {
var alternatingTableRowColors = function (settings) {
var tableRows = document.getElementById(settings.tableId).getElementsByTagName('tr');

for (var i = 0; i < tableRows.length; i++) {
if (i % 2 === 0) {
tableRows.style.background = settings.evenColor;
} else {
tableRows.style.background = settings.oddColor;
}
}
};

alternatingTableRowColors({
tableId: 'tableId',
evenColor: '#00ff00',
oddColor: '#ff0000'
});

}());
[/src]

Edit: Vermutlich wär's mit Klassen sinnvoller, aber so geht's.
 
Zuletzt bearbeitet:

gelöschter Benutzer

Guest

G
Dann aber bitte zusätzlich zum CSS3.

Javascript für Styling? *Haare rauf* So weit sind wir anscheinend schon!
 

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
  • Thread Starter Thread Starter
  • #10
Also ich blieb am Ende bei Kugelfischs Lösung hängen, da sie mir doch noch am Besten und vor allem unkompliziertesten erscheint (Der Fisch kennt mich einfach schon ;)). Sie ist nicht das NonPlusUltra, aber für meine Zwecke vertretbar.
 
Oben