Handling Events in jQuery – Few Advanced Notes and Faqs
Background:
We have already discussed about handling client events in jQuery (see earlier post). Obviously there are more things about jQuery events like binding client events to DOM element which are created dynamically, Cancelling the action of an event conditionally etc. Let’s have a look at few advanced topics on jQuery events.Adding event handler to future elements:
In my earlier post we already know about the bind() and unbind() methods provided by jQuery which is used to attach and detach event handlers to various elements on the page. Instead of bind() we can also use the click()/dblclick() methods to add different event handlers. We declare these things in the ready() event because we need that element to be loaded before we attach any event handler to that element.Since we can create DOM element dynamically, can we use this technique to attach event to the element. The answer is no, because when the dynamically created element is not yet present in the DOM when the ready event is executed. We can still manually attach the handler to the newly created element but there is a smarter way to do that using the live() method that jQuery provides.
Let’s consider the following example
<divid="myTestArea">
<ahref="#"onclick="AddElement();">Add Element</a>
<divclass="box">Existing Element</div>
</div>
<scripttype="text/javascript">
$(function()
    {
        $(".box").bind("mouseover", function()
        {
           $(this).css("background-color", "red");
        }).bind("mouseout", function()
        {
           $(this).css("background-color", "white");
        });
    });
    functionAddElement()
    {
       vardiv = $("<div></div>").addClass("box").text("Added Element");
       $("#myTestArea").append(div);
    }
</script>
Here, we have created an event handler for both “mouseover” and “mouseout” events to all elements using class selector “box”. Though we are dynamically adding the elements which have the same class “box”, things does not work out for those div which are created dynamically. In order to make this work we have to replace the bind method with the live() method and we are done. With the live() method jQuery will observe any changes to the DOM and will attach the event handler with those element that are newly created.
Similarly like the unbind() method we have the die() method that will work for detaching the event handler dynamically.
N.B: line() and die() methods are available on jQuery version 1.7 onwards.
Stop event method to perform: preventDefault or return false?
During the execution of a jQuery event we may need to stop the execution midway. One very popular way to do that is to write “return false” also we are all aware of the in-built jQuery event preventDefault(). So let’s have a closure look at these two options and different pros and cons about using these two.When we use the preventDefault() method it actually stops executing the current function, but does not stops the event to be bubble up. So the subsequent events will be triggered. In order to stop the event to bubble up we have to use the stopPropagation() method.
On the other hand return false, it actually does both. i.e calling return false is equivalent to calling both preventDefault() and stopPropagation().
So as we can see both these options are useful, but that depends on the need we have as a programmer. Consider a jQuery click() event of an anchor tag <a> and we have to stop the navigation. So we can write the preventDefault() at the beginning of the method so that user is not navigated away. We cannot use the return false in this case, because we have to use the return false once the execution of the function is done, and if there is an unhandled exception in between the return false statement will not be executed.
Attaching and detaching event handler: New ways to do that
As we have seen in earlier post. We can use the bind() and unbind() methods to attach and detach event handler respectively. Though these two methods are still available for backward compatibility, version1.7 onwards jQuery provides on() and off() functions to attach and detach event handlers.So the new way of doing this will be:
$('#mybutton').click(function() { returnfalse; }); // Adds another click event
$('#mybutton').off('click');
$('#mybutton').on('click.samplenamespace', function() { /* Code here */ });
$('#mybutton').off('click.samplenamespace');
Playing with DOM attributes: jQuery method attr() and prop()
While we have used jQuery selectors and Manipulate DOM in the earlier post, I have discussed about the attr() method to read and modify HTML attribute for DOM elements. If we look deep into the DOM tree, there are attributes and there are some properties of the DOM element. Apparently they looks similar but there are differences.From version 1.6 onwards, jQuery provides prop() method, which allows us to read and modify the properties of the DOM elemeny.The .prop() method provides a way to explicitly retrieve property values, and the .attr() retrieves attributes.
Attributes:
Attributes holds additional information about a HTML element and defined as name=”value”.If we look at the below example:
<input id="myText"type="text"value="myValue">
here, "type","value", "id" are attributes of the input elements.
Property:
Propertiesare representation of an attribute in the HTML DOM tree object. When the HTML code is parsed by the browser,corresponding DOM node is created as an object and all attributes are attached with that object as properties.In case of theexample,once browser renders the textbox, other properties like align, alt, autofocus, checked so on are added.
attr() gives us the value of element as defined in the html during the design.The advantage of using prop() iswe can get theoriginal value of an element also the current state values of element. So it is recommended to use the prop() methodto modify attributes via jquery.
Comments
Post a Comment