Does it hurt in performance when I loop through list-items and add a click-handler to all separate items?
The reason I do this is because I would only like to make the list item clickable if it contains an hyperlink.
The code I’m currently using is:
$('ul.paginator li').each(function() {
if ($('a', this).length > 0) {
$(this).css('cursor', 'pointer');
$(this).click(function() {
location.href = $('a', this).attr('href');
});
}
});
I’m not sure how much it might hurt performance, but have you considered using a somewhat simplified jQuery selector:
Incidentally, the performance would depend on the number of elements you’re searching through more than anything else. Just a few and it’s likely to be imperceptible, a few thousand and it will (probably) be noticeable.
Edited to reduce the expense of
has():This should be less expensive, as it will select only those
aelements within anli, and then move up to affect thatlielement.