Hier ist ein jQuery-Plugin, das ein Array aller Klassen zurückgibt, über die die übereinstimmenden Elemente verfügen
;!(function ($) {
$.fn.classes = function (callback) {
var classes = [];
$.each(this, function (i, v) {
var splitClassName = v.className.split(/\s+/);
for (var j = 0; j < splitClassName.length; j++) {
var className = splitClassName[j];
if (-1 === classes.indexOf(className)) {
classes.push(className);
}
}
});
if ('function' === typeof callback) {
for (var i in classes) {
callback(classes[i]);
}
}
return classes;
};
})(jQuery);
Verwenden Sie es wie
$('div').classes();
In Ihrem Fall kehrt zurück
["Lorem", "ipsum", "dolor_spec", "sit", "amet"]
Sie können auch eine Funktion an die Methode übergeben, die für jede Klasse aufgerufen werden soll
$('div').classes(
function(c) {
// do something with each class
}
);
Hier ist eine jsFiddle, die ich eingerichtet habe, um http://jsfiddle.net/GD8Qn/8/ zu demonstrieren und zu testen.
Minimiertes Javascript
;!function(e){e.fn.classes=function(t){var n=[];e.each(this,function(e,t){var r=t.className.split(/\s+/);for(var i in r){var s=r[i];if(-1===n.indexOf(s)){n.push(s)}}});if("function"===typeof t){for(var r in n){t(n[r])}}return n}}(jQuery);