javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > js生成唯一ID

JavaScript生成唯一ID的几种常用方法

作者:藤原とラふ店丶

这篇文章主要介绍了JavaScript生成唯一ID的几种常用方法,UUID 是通用唯一标识符的缩写,是由一个可以确保全球唯一性的算法生成的标识符,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

在 JavaScript 中生成唯一 ID(UUID)的方法有很多,根据场景需求(如唯一性强度、长度、可读性等)可选择不同方案。以下是几种常用方法:

1. 简单方案:时间戳 + 随机数(适合一般场景)

利用当前时间戳(毫秒级)结合随机数,实现简单且碰撞概率较低:

function generateSimpleId() {
  // 时间戳(毫秒)+ 3位随机数,确保同一毫秒内不重复
  return Date.now().toString(36) + Math.random().toString(36).substr(2, 3);
}

// 使用示例
console.log(generateSimpleId()); // 类似:"1h8t0d3-xyz"(36进制更短)

特点

2. 标准 UUID v4(推荐,通用性强)

UUID(通用唯一识别码)是行业标准,其中 v4 版本基于随机数生成,碰撞概率极低(可忽略),格式为 8-4-4-4-12 共36位:

function generateUUID() {
  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
    const r = Math.random() * 16 | 0;
    const v = c === 'x' ? r : (r & 0x3 | 0x8);
    return v.toString(16);
  });
}

// 使用示例
console.log(generateUUID()); // 类似:"f47ac10b-58cc-4372-a567-0e02b2c3d479"

特点

3. 更安全的随机数(基于 crypto API)

浏览器环境下可使用 crypto.getRandomValues 生成加密级随机数,进一步降低碰撞风险:

function generateSecureUUID() {
  const array = new Uint8Array(16);
  window.crypto.getRandomValues(array);
  
  // 符合 UUID v4 格式:第6位固定为4,第8位固定为8-11之间的值
  array[6] = (array[6] & 0x0f) | 0x40;
  array[8] = (array[8] & 0x3f) | 0x80;
  
  return Array.from(array, byte => ('0' + (byte & 0xff).toString(16)).slice(-2))
    .join('')
    .replace(/^(.{8})(.{4})(.{4})(.{4})(.{12})$/, '$1-$2-$3-$4-$5');
}

// 使用示例
console.log(generateSecureUUID()); // 标准UUID格式,随机数更安全

特点

4. 短ID(适合需要短标识的场景)

生成更短的唯一ID(如8-10位),可通过基数转换(36进制/62进制)实现:

function generateShortId(length = 8) {
  const chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
  let id = '';
  for (let i = 0; i < length; i++) {
    // 随机取字符(使用crypto提高随机性)
    const randomIndex = Math.floor(window.crypto.getRandomValues(new Uint32Array(1))[0] / (0xFFFFFFFF + 1) * chars.length);
    id += chars[randomIndex];
  }
  return id;
}

// 使用示例
console.log(generateShortId()); // 类似:"xY3p7Q9z"

特点

选择建议:

这些方法基本能覆盖大部分前端生成唯一ID的需求,可根据实际场景选择。

总结

到此这篇关于JavaScript生成唯一ID的几种常用方法的文章就介绍到这了,更多相关js生成唯一ID内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文