使用JavaScript生成UUID/GUID的三种方法

 更新时间:2026年03月15日 13:54:54   作者:hefeng_aspnet  
文章介绍了三种使用JavaScript生成UUID/GUID的方法及其优缺点,方法1简单但格式不规范;方法2解决了格式问题但可能产生碰撞;方法3结合时间戳解决了格式和碰撞问题,主流浏览器支持,但IE不支持,需要的朋友可以参考下

UUID 是「Universally Unique IDentifier」(通用唯一识别码)的缩写,目的是唯一的标示信息。UUID 包含 32 个十六进位数字,并用「-」分隔成五组,每组分别有8、4、4、4、12的数字。例如:「550e8400-e29b-41d4-a716-446655440000」是一组完整的 UUID。

这里列了几种使用 JavaScript 产生 UUID / GUID的方法、优缺比较。

方法 1

最简单的方法就是使用 Math.random() 产出任意16进制数字,但

格式不符合 RFC4122 规范

Math.random() 产出的数字可能重复 (collision),保存前必须做比对
function _uuid() {
  function s4() {
    return Math.floor((1 + Math.random()) * 0x10000).toString(16).substring(1);
  }
  return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4();
}
var uuid = _uuid(); //b3165466-df5b-c3d7-0e94-79d94e8c692f

接下来的方法都是基于 Math.random() 做改善,不管是改进格式或唯一性。

方法 2

先摆好格式,再利用 Math.random() 产出任意数字填入格式中。这个方法解决了方法 1 的格式问题,但仍可能有 collision。

function _uuid() {
  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {var r = Math.random()*16|0,v=c=='x'?r:r&0x3|0x8;return v.toString(16);});
}
var uuid = _uuid(); //5fc84f46-5743-4ed3-a94d-1ba63b8022a5

方法 3

结合 time stamp 与方法 2,同时解决了格式和 collision 问题。

由于加上 Performance.now() (亚毫秒级的时间戳记),很难产生 collision。主流浏览器皆支持,但 IE 只支持 10 以上或 Edge。

function _uuid() {
  var d = Date.now();
  if (typeof performance !== 'undefined' && typeof performance.now === 'function'){
    d += performance.now(); //use high-precision timer if available
  }
  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
    var r = (d + Math.random() * 16) % 16 | 0;
    d = Math.floor(d / 16);
      return (c === 'x' ? r : (r & 0x3 | 0x8)).toString(16);
  });
}

测试

for(var i = 0; i < 10; i++) {
  console.log(_uuid());
}
b382bd5-becd-4d93-8d3f-98aad78a049e
e3dea0f5-37f2-4d79-ae58-490af3228069
3e8d1c2b-f9f9-4a74-a8af-a4e8bebea438
eefbada8-efee-439a-af83-a80dde423dd6
8084d5dd-4f91-4590-927c-4751b49f2de0
06423d2c-1d62-429b-b6f9-de0a8d4ea95f
8b86b39e-5f2e-4abd-a8f0-2108a39a1d8a
62c8628e-e2e2-439d-80cd-b86e31e4bd59
1322e5db-91b0-4f12-94bd-fb4989d3cb95
0db3399e-55c3-44ba-822e-afcabf9b702b

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

相关文章

  • Bootstrap popover用法详解

    Bootstrap popover用法详解

    这篇文章主要为大家详细介绍了Boostrap popover用法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • jstl中判断list中是否包含某个值的简单方法

    jstl中判断list中是否包含某个值的简单方法

    下面小编就为大家带来一篇jstl中判断list中是否包含某个值的简单方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • JavaScript 弱引用强引用底层示例详解

    JavaScript 弱引用强引用底层示例详解

    这篇文章主要为大家介绍了JavaScript 弱引用强引用底层示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 使用JSON.parse将json字符串转换成json对象的时候会出错

    使用JSON.parse将json字符串转换成json对象的时候会出错

    使用JSON.parse将json字符串转换成json对象的时候会出错,主要是双引号,回车换行等影响明显,左尖括号和右尖括号也会导致显示问题
    2014-09-09
  • uniapp中单选按钮的实现代码示例

    uniapp中单选按钮的实现代码示例

    uniapp官方虽然提供了uni-data-checkbox,含括了单选和多选框功能,但是它功能是在不能满足需求,下面这篇文章主要给大家介绍了关于uniapp中单选按钮的实现代码,需要的朋友可以参考下
    2023-01-01
  • JS获取input[file]的值并显示在页面的实现方法

    JS获取input[file]的值并显示在页面的实现方法

    下面小编就为大家分享一篇JS获取input[file]的值并显示在页面的实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • js数字转中文两种实现方法

    js数字转中文两种实现方法

    在前端开发中有时候会需要到将阿拉伯数字转化为中文,当前做个记录,提供自己之后翻阅,这篇文章主要给大家介绍了关于js数字转中文两种实现方法的相关资料,需要的朋友可以参考下
    2023-10-10
  • javascript图片相似度算法实现 js实现直方图和向量算法

    javascript图片相似度算法实现 js实现直方图和向量算法

    这篇文章主要介绍了javascript实现图片相似度算法,大家参考使用吧
    2014-01-01
  • 简单理解js的prototype属性及使用

    简单理解js的prototype属性及使用

    这篇文章主要介绍了简单理解js的prototype属性及使用 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • JavaScript伪数组和数组的使用与区别

    JavaScript伪数组和数组的使用与区别

    这篇文章主要给大家介绍了关于JavaScript伪数组和数组使用与区别的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05

最新评论