Several ways to generate unique IDs in JavaScript

Several ways to generate unique IDs in JavaScript

Possible solutions

1. Math.random generates random numbers in [0,1)

//This time I ran the generated value: 0.5834165740043102 
Math.random();

2. Get the current timestamp Date.now

//Now the timestamp is 1482645606622
Date.now();

3. Convert decimal to other base strings Number.toString

//Convert 1482645606622 into binary: 10101100100110100100100001001000011011110 
(1482645606622).toString(2);

//Convert to hexadecimal: 159349090de ObjectID in MongoDB is a 24-digit hexadecimal number (1482645606622).toString(16);

//The maximum base supported is hexadecimal, using characters 0-9a-z: ix48wvry 
(1482645606622).toString(36);

Improved version 1: Random number + toString()

1. Random number version

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(){
 return Math.random().toString()
}

//Generate an ID similar to 0.1283460319177394
GenNonDuplicateID()

2. Random number version hexadecimal version

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(){
 return Math.random().toString(16)
}

//The function will generate an ID like 0.c1615913fa915
GenNonDuplicateID()

3. Random number version hexadecimal version

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(){
 return Math.random().toString(36)
}

//The function will generate an ID like 0.hefy7uw6ddzwidkwcmxkzkt9
GenNonDuplicateID()

4. Random number version hexadecimal version

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(){
 return Math.random().toString(36).substr(2)
}

//The function will generate an ID similar to 8dlv9vabygks2cbg1spds4i
GenNonDuplicateID()

Summarize

Advantages: Using toString's base conversion can achieve shorter strings to represent a wider range of

Disadvantage: Using a random number as an ID will inevitably result in two identical IDs as the number of uses accumulates.

Improved version 2

1. Introduce timestamp + hexadecimal version

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(){
 let idStr = Date.now().toString(36)
 idStr += Math.random().toString(36).substr(2)
 return idStr
}

//The function will generate an ID similar to ix49sfsnt7514k5wpflyb5l2vtok9y66r
GenNonDuplicateID()

2. Introduce timestamp + hexadecimal version + random number length control

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(randomLength){
 let idStr = Date.now().toString(36)
 idStr += Math.random().toString(36).substr(2,randomLength)
 return idStr
}

// GenNonDuplicateID(3) will generate an ID similar to ix49wl2978w
GenNonDuplicateID(3)

However, the first few digits of the ID generated in this way are always the same.

3. Introduce timestamp + prepend hexadecimal to random number + control random number length

/**
 * Generate a unique ID
 */
function GenNonDuplicateID(randomLength){
 return Number(Math.random().toString().substr(2,randomLength) + Date.now()).toString(36)
}
//GenNonDuplicateID() will generate an ID similar to rfmipbs8ag0kgkcogc
GenNonDuplicateID()

Summarize

Just use the timestamp so that multiple people can access the same data at the same time. Adding random numbers can achieve uniqueness. Plus custom length, UUID is more flexible.

Summarize

Universal solution:

/**
 * Generate a unique ID
 * @param { Number } randomLength 
 */
function getUuiD(randomLength){
 return Number(Math.random().toString().substr(2,randomLength) + Date.now()).toString(36)
}

The above are the details of several ways to generate unique IDs with JavaScript. For more information about how to generate unique IDs with JavaScript, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Javascript method to generate globally unique identifier (GUID, UUID)
  • Each component in extjs must have a unique ID, otherwise an error will occur

<<:  Linux forced release of occupied ports and Linux firewall port opening method detailed explanation

>>:  Summary of the operation records of changing MyISAM storage engine to Innodb in MySQL

Recommend

Ideas and codes for implementing waterfall flow layout in uniapp applet

1. Introduction Is it considered rehashing old st...

21 MySQL standardization and optimization best practices!

Preface Every good habit is a treasure. This arti...

JavaScript canvas implements graphics and text with shadows

Use canvas to create graphics and text with shado...

The difference between the four file extensions .html, .htm, .shtml and .shtm

Many friends who have just started to make web pag...

An article to understand Linux disks and disk partitions

Preface All hardware devices in the Linux system ...

Summary of English names of Chinese fonts

When using the font-family property in CSS to ref...

A brief analysis of the use of the HTML webpack plugin

Using the html-webpack-plugin plug-in to start th...

CSS isolation issue in Blazor

1. Environment VS 2019 16.9.0 Preview 1.0 .NET SD...

Solution to the problem that Docker cannot stop or delete container services

Preface Today, a developer gave me feedback that ...

Detailed explanation of the steps of using ElementUI in actual projects

Table of contents 1. Table self-sorting 2. Paging...

VMware vsphere 6.5 installation tutorial (picture and text)

vmware vsphere 6.5 is the classic version of vsph...

The most common declaration merge in TS (interface merge)

Table of contents 1. Merge interface 1.1 Non-func...

React Native scaffolding basic usage detailed explanation

Build the project Execute the command line in the...