top button
Flag Notify
    Connect to us
      Site Registration

Site Registration

Explain .bind() vs .live() vs .delegate() vs .on()

+3 votes
1,419 views
Explain .bind() vs .live() vs .delegate() vs .on()
posted Jul 10, 2015 by Shivaranjini

Share this question
Facebook Share Button Twitter Share Button LinkedIn Share Button

1 Answer

+1 vote
 
Best answer

All these 4 jQuery methods are used for attaching events to selectors or elements. But they all are different from each other.

.bind():

This is the easiest and quick method to bind events. But the issue with bind() is that it doesn't work for elements added dynamically that matches the same selector. bind() only attach events to the current elements not future element. Above that it also has performance issues when dealing with a large selection.

.live():

This method overcomes the disadvantage of bind(). It works for dynamically added elements or future elements. Because of its poor performance on large pages, this method is deprecated as of jQuery 1.7 and you should stop using it. Chaining is not properly supported using this method.

.delegate():

The .delegate() method behaves in a similar fashion to the .live() method, but instead of attaching the selector/event information to the document, you can choose where it is anchored and it also supports chaining.

.on():

Since live was deprecated with 1.7, so new method was introduced named ".on()". This method provides all the goodness of previous 3 methods and it brings uniformity for attaching event handlers.

answer Jul 20, 2015 by Karthick.c
Similar Questions
0 votes

I know both are pre-defined functions in jquery.I need to know what is the use?Please give some examples for both functions.

...