javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > JavaScript生成UUID/GUID

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

作者: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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

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