In this article, we will be discussing the PreventDefault & stopPropagation methods with suitable code examples for each condition & then we will see the difference between the PreventDefault vs stopPropagation.
preventDefault() Method: It is a method present in the event interface. This method prevents the browser from executing the default behavior of the selected element. This method can cancel the event only if the event is cancelable. For example, there are some events that can not be prevented, such as the scroll and wheel event.
Parameter: This method does not accept any parameter.
We will see the approaches for applying both methods with the help of the examples.
Example 1: Preventing a link from following the URL so that the browser can not go to another page.
Example 2: It prevents the user from checking the checkboxes. Usually, when we click on the checkboxes, it toggles but nothing will work, after calling the preventDefault() method.
stopPropagation() event method: This method is used to prevent the parent element from accessing the event. Basically, this method is used to prevent the propagation of the same event from being called. For eg, we have a button element inside a div tag and there is an onclick event on both of them, then whenever we try to activate the event attached to the button element, then the event attached to the div element also gets executed because div is the parent of the button element.
We can solve this problem by using the stopPropagation() method because this will prevent the parent from accessing the event.
Here, after clicking on the button, both functions will be executed.
Now, in this case, we have added an event.stopPropagation() method, then the only function of the button element will be executed.
Difference between preventDefault() vs stopPropagation() Methods:
|Prevent the default action of browsers taking on that event.||Prevent further propagation of current events by parent or child elements.|
|It is a method present in the Event interface.||This method is also present in the Event interface.|
|For example, it prevents the browser from following a link.||It can not stop the default behavior of the browser.|
Its syntax is -:
Its syntax is -:
|This method does not take any parameters||This method also does not take any arguments in its definition|
|Its supported browsers are -: chrome, firefox, safari, opera, etc||Its supported browsers are -: chrome, firefox, safari, opera, etc|
|It does not return value||It does not have any return type|
|Its uses the DOM version of DOM Level 3 Events||Its uses the DOM version of DOM Level 2 Events|