Hii @kartik,
It is possible to list all event listeners in JavaScript. You just have to hack the prototype's method of the HTML elements (before adding the listeners).
function reportIn(e){
var a = this.lastListenerInfo[this.lastListenerInfo.length-1];
console.log(a)
}
HTMLAnchorElement.prototype.realAddEventListener = HTMLAnchorElement.prototype.addEventListener;
HTMLAnchorElement.prototype.addEventListener = function(a,b,c){
this.realAddEventListener(a,reportIn,c);
this.realAddEventListener(a,b,c);
if(!this.lastListenerInfo){ this.lastListenerInfo = new Array()};
this.lastListenerInfo.push({a : a, b : b , c : c});
};
Now every anchor element (a) will have a lastListenerInfo property wich contains all of its listeners. And it even works for removing listeners with anonymous functions.
Another method
This solution will work only on Google Chrome or Chromium-based browsers.
We are going to use this website as an example.
Let’s say you wanted to find all the event listeners attached to the search icon DOM element.
data:image/s3,"s3://crabby-images/50024/5002428f8dc8f7792127b94ed39f5d48f40e9e51" alt="image"
Right-click on the search icon button and choose “inspect” to open the Chrome developer tools.
data:image/s3,"s3://crabby-images/a00b0/a00b05c6959790d7c4043143c03c23bd07ee719c" alt="image"
Once the dev tools are open, switch to the “Event Listeners” tab and you will see all the event listeners bound to the element.
data:image/s3,"s3://crabby-images/4d1d6/4d1d6d98a960263fff0056d1adcc8cc393c01269" alt="image"
You can expand any event listener by clicking the right-pointing arrowhead.
When you expand an event listener and hover over the element, the “remove” button will appear. It can be used to delete the event listener.
data:image/s3,"s3://crabby-images/56099/56099fd905be89ed508cd35cf163e560b165ba4d" alt="image"
Clicking on the filename main.min.js:6 takes you directly to the event listener callback function source by automatically switching you to the “sources” tab.
data:image/s3,"s3://crabby-images/acfbb/acfbbe8fa72827412bdd480a8269551e89d784a5" alt="image"
As you can see in the screenshot below, you have been taken to the exact location of the event listener callback function.
data:image/s3,"s3://crabby-images/da956/da956d503960cec55f2f3c22688ee54ada53c2ba" alt="image"
We can’t see the event listener code properly right now since the code is minified.
Click on the {} icon to format the code.
data:image/s3,"s3://crabby-images/c1bec/c1becb7f42a5f07b94852b22b187100383142da5" alt="image"
Hope it helps!
In any case if you need to know more about Javascript code, then enroll with our Java certification course and learn from the top level instructors.