Several getElementsByClassName() prototype methods in about 140 bytes (more or less). Useful for Internet Explorer <9.0 and (few) other old web browsers that do not support HTML5. Done for 140byt.es.
All "full" versions perfectly match the W3C specification, as far as I know. They support multiple class names in every order and class names that start with or contain dashes or nonascii characters.
The short version (138 bytes) does not support searching for multiple class names and fails when the query string contains any whitespace character.
The "annotated" version is a compromise with a few restrictions (see the comment below). It supports searching for multiple class names and should work in most web browsers.
@snowlord, I fixed your formatting.
this
is for use in a prototype.@jed, it's good to have a recursive approach for comparison but I'm afraid
firstChild
+nextSibling
is longer thangetElementsByTagName
. And searching for multiple classes does not work as expected. But thanks to you (good to know:search
andmatch
do not search for strings, they do an implicitnew RegExp
) we are down at 155 bytes.What I don't understand is your
||""
. Is this necessary?