Forum:Alternative row colors in a table

I have a page that I update almost constantly, and I have the rows in the tables alternating colors, but I am doing this manually.

ie. bgcolor="#554444" for one row and bgcolor="#665555" for the next, but I have to re-organize them all the time, into a different order, so I have to manually change the bgcolor every time.

Here is the page, so you can see what I am talking about: http://www.wowwiki.com/Server:Ursin_US/Progression

How can I make the color's alternate automatically?

98.24.209.203 18:06, 21 April 2009 (UTC)
 * Wookieepedia was able to do this; see w:c:starwars:MediaWiki:Common.js. However, I'm not exactly sure what to copy and paste, it also fails for me. You may also have to copy w:c:starwars:MediaWiki:Functions.js. --Michaeldsuarez (Talk) (Deeds) 18:17, 21 April 2009 (UTC)


 * Aye, until more browsers support the more advanced CSS functions that do alternating line colours, JS is pretty much the only other option. 18:29, 21 April 2009 (UTC)


 * As how the code is designed on Wookieepedia it only adds #f9f9f9 so you should decide in a single color unless you are planing to add modifications to the code, an obvious reminder that non-js activated persons will not see this alternating colors. The codes you require are:

/* Source: http://www.dustindiaz.com/getelementsbyclass/ getElementsByClass, * which complements getElementById and getElementsByTagName, returns an array * of all subelements of node that are tagged with a specific CSS class * (searchClass) and are of the tag name tag. If tag is null, it * searches for any suitable elements regardless of the tag name. Example: * getElementsByClass('infobox', document.getElementById('content'), 'div') * selects the same elements as the CSS declaration #content div.infobox */ function getElementsByClass(searchClass, node, tag) { var classElements = new Array; if(node == null) node = document; if(tag == null) tag = '*'; var els = node.getElementsByTagName(tag); var elsLen = els.length; var tester = new ClassTester(searchClass); for(i = 0, j = 0; i < elsLen; i++) { if(tester.isMatch(els[i])) { classElements[j] = els[i]; j++; }   }    return classElements; } function ClassTester(className) { this.regex = new RegExp('(^|\\s)' + className + '(\\s|$)'); } ClassTester.prototype.isMatch = function(element) { return this.regex.test(element.className); } // end getElementsByClass

function addAlternatingRowColors { var infoboxes = getElementsByClass('infobox', document.getElementById('content')); if(infoboxes.length == 0) return; for(var k = 0; k < infoboxes.length; k++) { var infobox = infoboxes[k]; var rows = infobox.getElementsByTagName('tr'); var changeColor = false; for(var i = 0; i < rows.length; i++) { if(rows[i].className.indexOf('infoboxstopalt') != -1) break; var ths = rows[i].getElementsByTagName('th'); if(ths.length > 0) continue; if(changeColor) rows[i].style.backgroundColor = '#f9f9f9'; changeColor = !changeColor; }   } } addOnloadHook(addAlternatingRowColors);
 * Table must be wrap inside a div with class "infobox". Header cells will be ignored. Adding class "infoboxstopalt" to the table row (  or   ) will stop the alternation in that spot and below. If you do modifications i'm interested to see them once you finish, thanks --
 * You appear to be asking for WoWWiki, why you would ask here instead of on WW itself baffles me, but the technique to do this (already implemented before this discussion) is to specify the table as class="zebra". See also wowwiki:User:Pcj/Zebra tables. --Pcj (T&bull;C) 23:25, 29 April 2009 (UTC)