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

 更新时间:2025年08月22日 09:45:49   作者:藤原とラふ店丶  
这篇文章主要介绍了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进制更短)

特点

  • 实现简单,长度较短(约12-15位);
  • 适合前端临时标识(如DOM元素ID、临时缓存键);
  • 高并发下可能有极低碰撞风险(可增加随机数长度降低概率)。

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"

特点

  • 符合 UUID 标准,通用性强(后端、数据库等场景兼容);
  • 随机数生成,碰撞概率极低(适合生产环境);
  • 长度固定(36位),包含连字符,可读性较好。

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格式,随机数更安全

特点

  • 随机数质量更高(加密级),适合安全性要求高的场景(如token、会话ID);
  • 需浏览器支持 crypto API(几乎所有现代浏览器都支持);
  • 仍符合 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"

特点

  • 长度可控(默认8位,碰撞概率随长度增加而降低);
  • 包含大小写字母和数字,可读性较好;
  • 适合URL参数、短链接等需要简短标识的场景。

选择建议:

  • 一般前端场景:优先用 UUID v4(通用且可靠);
  • 高安全性场景:用 crypto 生成的 UUID
  • 短标识需求:用 短ID生成函数(注意长度与碰撞风险平衡);
  • 简单临时标识:用 时间戳+随机数(实现最简单)。

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

总结

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

相关文章

  • JavaScript WebSocket实现实时双向聊天

    JavaScript WebSocket实现实时双向聊天

    这篇文章主要为大家详细介绍了如何基于JavaScript WebSocket实现实时双向聊天,文中的示例代码讲解详细,有需要的小伙伴可以参考一下
    2024-04-04
  • 手把手教你 CKEDITOR 4 扩展插件制作

    手把手教你 CKEDITOR 4 扩展插件制作

    这篇文章主要介绍了手把手教你 CKEDITOR 4 扩展插件制作,结合具体实例形式详细分析了CKEditor4插件制作的步骤与相关操作注意事项,需要的朋友可以参考下
    2019-06-06
  • js href的用法

    js href的用法

    关于js window.location.href location.href parent.location.href top.location.href 的用法
    2010-05-05
  • 详解js中构造流程图的核心技术JsPlumb(2)

    详解js中构造流程图的核心技术JsPlumb(2)

    这篇文章主要介绍了js中构造流程图的核心技术JsPlumb,jsPlumb是一个强大的JavaScript连线库,它可以将html中的元素用箭头、曲线、直线等连接起来,适用于开发Web上的图表、建模工具等,需要的朋友可以参考下
    2015-12-12
  • element-ui组件输入框之放大镜搜索图标问题

    element-ui组件输入框之放大镜搜索图标问题

    这篇文章主要介绍了element-ui组件输入框之放大镜(搜索图标)的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-11-11
  • HTML5+Canvas实现图片添加水印功能

    HTML5+Canvas实现图片添加水印功能

    在现代Web开发中,图像处理是一个常见的需求,尤其是为图片添加水印,下面我们就来看看如何使用HTML5的Canvas技术为图片添加水印,需要的可以了解下
    2024-11-11
  • javascript编程异常处理实例小结

    javascript编程异常处理实例小结

    这篇文章主要介绍了javascript编程异常处理的方法,结合实例形式分析总结了JavaScript编程中异常处理的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • javascript创建对象的3种方法

    javascript创建对象的3种方法

    这篇文章主要介绍了javascript创建对象的3种方法,对比分析js创建对象三种方式的优缺点,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • JavaScript:Div层拖动效果实例代码

    JavaScript:Div层拖动效果实例代码

    这篇文章介绍了JavaScript:Div层拖动效果实例代码,有需要的朋友可以参考一下
    2013-08-08
  • JavaScript实现拖拽和缩放效果

    JavaScript实现拖拽和缩放效果

    这篇文章主要为大家详细介绍了JavaScript实现拖拽和缩放效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08

最新评论