views:

172

answers:

3

The question says it all. Which one is better and when to use what, I never use jQuery live() as I am using liveQuery plugin for a couple of years, I am used to it and still continue using it. But I want to know the subtle differences between the two and when to use each of it?

A: 

liveQuery plugin was created initially, and then was migrated to jQuery itself.

Mendy
+2  A: 

The "live" function native to jQuery leverages the bubbling of events up the DOM. The "liveQuery" plugin, by contrast, uses the selector to find elements in the DOM and attach event handlers directly.

In my opinion you're way better off using the "live" function when possible, because it involves less DOM traversal etc. For example, hooking event handlers to things throughout a big table can be kind-of slow with liveQuery but not slow at all with "live". There may be some issues (with IE of course) that force you to use liveQuery sometimes, though jQuery 1.4 has improved "live" considerably.

Pointy
If the table is already in the document when live() is called then there will still be a DOM traversal. e.g. $("td").live() still finds every td element.
Sean Hogan
+1  A: 

As Pointy said, live() leverages the bubbling of events up the DOM (event delegation). Also, for each $(selector).live(type, handler) call, jQuery only calls handler on the $(event.target).closest(selector) element - that is, the nearest matching ancestor-or-self element of the event target. And, of course, live() doesn't support anything like livequery( matchedFn, unmatchedFn ).

Implications:

  • $(selector).live() still requires a traversal of the DOM (obviously). However, if you load jQuery and attach live() handlers in the document head then there is no document body to search yet. Similarly if you insert new content into the page.
  • live() does less work when being configured - it doesn't have to attach handlers to every matched element
  • live() does more work in handling events - it has to traverse ancestors of the event target, finding elements that match the selector
  • $("div").live() is different to $("div").livequery() as it only works for the closest div to the event target
  • Similarly, $("div, p").live() is different to $("div").live(); $("p").live();
Sean Hogan