As you know there are several portable mechanisms to make unique ID’s in javascript, running inside a browser page. Here is my very simple but still very usable mechanism.
I use the timer ID value, which is returned by setTimeout()
calls. Therefore I am able to create a function that is guaranteed to return an integer which is different from any previous or future return values of the same function , while inside the same page session.
1 2 3 |
function pageuid (uid) { return uid = setTimeout(function() { clearTimeout(uid) }, 0); } |
Above returns unique integers. Obviously made by some internal counter with an arbitrary base. In my IE8 , I have this :
1 2 3 4 5 6 7 8 9 |
Page UID: : 120280629 Page UID: : 120280631 Page UID: : 120280633 Page UID: : 120280635 Page UID: : 120280637 Page UID: : 120280639 Page UID: : 120280641 Page UID: : 120280643 Page UID: : 120280645 |
Is this “unique enough” ? Well, on the level of a page where it is used it is unique enough, indeed. If we want this to be unique enough for (for example) ajax postings to the server, we can simply “adorn” it with some prefix, or suffix. In form of a string made from document.location
, or whichever fancy and clever mechanism one prefers.
But still, here is an extremely simple and still perfectly usable heart of the algorithm for generating UID’s in javascript running inside a browser page.
My current UID generator is this:
1 2 3 4 5 6 7 8 9 10 11 12 |
// function pageuid (uid) { return pageuid.prefix() + pageuid.delimiter + (uid = setTimeout(function() { clearTimeout(uid) }, 0)) + pageuid.delimiter + pageuid.suffix() ; } // pageuid.delimiter = "-" ; pageuid.suffix = function () { return (new Date()).getTime() ; } pageuid.prefix = function () { return "dbj" ; } |
This is certainly “good enough” as an UID, but not as an GUID, where G stands for “Globaly”. But, for simple scripting inside a single page, this is quite “good enough”. Here is the test and its results :
1 2 3 4 5 6 7 8 9 10 11 |
// function pad ( n, max_ ) { if ( (""+n).length < max_ ) n = pad ( "0" + n, max_ ) ; return n ; } // function my_simple_uid_test ( max_, s_ ) { s_ = "" ; for ( var j=0; j < max_ ; ++j ) s_ += pad(j,4) + ": " + pageuid() + "\n" ; return s_ ; } |
The test results are :
1 2 3 4 5 6 7 8 9 10 |
0000: dbj-2323802-1233761594093 0001: dbj-2323803-1233761594093 0002: dbj-2323804-1233761594093 0003: dbj-2323805-1233761594093 0004: dbj-2323806-1233761594093 0005: dbj-2323807-1233761594093 0006: dbj-2323808-1233761594093 0007: dbj-2323809-1233761594093 0008: dbj-2323810-1233761594093 0009: dbj-2323811-1233761594093 |
Here also lies an explanation of why can’t we just use the current time as an uid. Because time resolution is not small enough. In the code above, since test is a quite tight and short loop, getTime()
, result is rendered useless as an unique value. The whole loop finished in under one milli second, so all the time values are that same one milli second. They are all the same. Instead, I also used my little timer ID mechanism (and its counter) and, I get true and real UID’s for the current page.