Skip to content Skip to sidebar Skip to footer

Faster Way To Select An Element With A Given Id

I have a question. Let's say we have the following html tag:
I am a div
Τhis div exists on the dom(it is not generated by javascript) If I want to

Solution 1:

The fastest way is:

document.getElementById("foo");

Setting this to a variable for reuse will prevent the need to find it over and over again, so yes that is the way to go.

if you want to make a jQuery object out of it:

var fooDiv = document.getElementById("demo");
var $fooDiv = $(fooDiv);

Solution 2:

Creating a reference to the element will always be at least as fast as selecting it (be it with jQuery selector $() or document.getElement...).

That said, I would go for var d = if you are going to use it several times in a function or a limited scope.

Not only you will have the reference saved, but also it will be shorter and more readable.

Benchmarks:

http://jsbench.github.io/#3621d3b9b571cc3640fa988b42c5c873(you might have to run it twice; first time it'll inject JQuery from CDN)

Saving element reference is by far the fastest solution.

A x10 requested element gets the following results (the more ops/sec the better):

[no var] document.getElementById: 3,206,218 ops/sec [var] document.getElementById: 34,382,745 ops/sec

[no var] $(): 148,649 ops/sec [var] $(): 1,390,771 ops/sec

That's about x10 times faster with either JavaScript getElementById or JQuery selector

Solution 3:

It depends really on how you want to use your jquery DOM handle. Consider a scenario where i want to work with a structure as such

<section><divid="t1"></div><divid="t2"></div><divid="t3"></div></section>

the fastest way i know to access #t2 would be

var d = $('#t2');

then d can be used later as you wish. But consider a case where you need to use the <section> and a div in your script, the fastest way to do that would be

var secD = $('section').eq(0); 
//assuming it comes first in the dom, //better still put an id on it for easy access.var t1D = secD.find('#t1');
//this eliminates the need for jquery to do global lookups and reduces the scope of search

Solution 4:

Considering this element in the DOM

<div id='foo'>I am a div</div>

Using the jQuery() or $() function will check the DOM and return a collection of matched elements either found in the DOM and create an object with it.

If you use this object more than once, it would be wiser to store it and just reuse it. But now, as j08691 said, you could run some tests and see what's more effective. As these operations are super fast, you should try to do it with a loop for 10000 times and console.log the time (difference between time at start and time at end — new Date())

I think that the jQuery function is super optimised and fast so you won't be able too feel a difference under a very high number of repetitions. There are way more things to optimise in web such as images and animations.

In a nutshell, it is microscopic, but a reference should be faster than a method that creates an object.

Something you should keep in mind during the tests would be the size of the DOM. See if you only have one div in the body or a thousand would influence the results..

Post a Comment for "Faster Way To Select An Element With A Given Id"