UUID(uuid)js 生成
全局唯一标识符(GUID,Globally Unique Identifier)也称作 UUID(Universally Unique IDentifier) 。
GUID是一种由算法生成的二进制长度为128位的数字标识符。GUID 的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中的 x 是 0-9 或 a-f 范围内的一个32位十六进制数。在理想情况下,任何计算机和计算机集群都不会生成两个相同的GUID。
GUID 的总数达到了2^128(3.4×10^38)个,所以随机生成两个相同GUID的可能性非常小,但并不为0。GUID一词有时也专指微软对UUID标准的实现。
在生成一些节点的时候需要通过唯一ID来标记,有如下高票答案可供参考
/** Generate a random uuid.** USAGE: Math.uuid(length, radix)* length - the desired number of characters* radix - the number of allowable values for each character.** EXAMPLES:* // No arguments - returns RFC4122, version 4 ID* >>> Math.uuid()* "92329D39-6F5C-4520-ABFC-AAB64544E172"** // One argument - returns ID of the specified length* >>> Math.uuid(15) // 15 character ID (default base=62)* "VcydxgltxrVZSTV"** // Two arguments - returns ID of the specified length, and radix. (Radix must be <= 62)* >>> Math.uuid(8, 2) // 8 character ID (base=2)* "01001010"* >>> Math.uuid(8, 10) // 8 character ID (base=10)* "47473046"* >>> Math.uuid(8, 16) // 8 character ID (base=16)* "098F4D35"*/(function() {// Private array of chars to usevar CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');Math.uuid = function (len, radix) {var chars = CHARS, uuid = [], i;radix = radix || chars.length;if (len) {// Compact formfor (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random()*radix];} else {// rfc4122, version 4 formvar r;// rfc4122 requires these charactersuuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';uuid[14] = '4';// Fill in random data. At i==19 set the high bits of clock sequence as// per rfc4122, sec. 4.1.5for (i = 0; i < 36; i++) {if (!uuid[i]) {r = 0 | Math.random()*16;uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];}}}return uuid.join('');};// A more performant, but slightly bulkier, RFC4122v4 solution. We boost performance// by minimizing calls to random()Math.uuidFast = function() {var chars = CHARS, uuid = new Array(36), rnd=0, r;for (var i = 0; i < 36; i++) {if (i==8 || i==13 || i==18 || i==23) {uuid[i] = '-';} else if (i==14) {uuid[i] = '4';} else {if (rnd <= 0x02) rnd = 0x2000000 + (Math.random()*0x1000000)|0;r = rnd & 0xf;rnd = rnd >> 4;uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];}}return uuid.join('');};// A more compact, but less performant, RFC4122v4 solution:Math.uuidCompact = function() {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);});};})();function generateUUID() {var d = new Date().getTime();var uuid = '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);});return uuid;};答案下面的评论云:这个方案下的碰撞率不及1/2^^122
另外给大家推荐几种算法
算法2
function guid() {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);});}算法3
function guid() {function S4() {return (((1+Math.random())*0x10000)|0).toString(16).substring(1);}return (S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4());}算法4
function uuid(len, radix) {var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');var uuid = [], i;radix = radix || chars.length;if (len) {// Compact formfor (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random()*radix];} else {// rfc4122, version 4 formvar r;// rfc4122 requires these charactersuuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';uuid[14] = '4';// Fill in random data. At i==19 set the high bits of clock sequence as// per rfc4122, sec. 4.1.5for (i = 0; i < 36; i++) {if (!uuid[i]) {r = 0 | Math.random()*16;uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];}}}return uuid.join('');}这个可以指定长度和基数。比如
// 8 character ID (base=2)uuid(8, 2) // "01001010"// 8 character ID (base=10)uuid(8, 10) // "47473046"// 8 character ID (base=16)uuid(8, 16) // "098F4D35"算法5
function uuid() {var s = [];var hexDigits = "0123456789abcdef";for (var i = 0; i < 36; i++) {s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);}s[14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01s[8] = s[13] = s[18] = s[23] = "-";var uuid = s.join("");return uuid;}当然了,个人还是推荐算法一的,小伙伴们可以根据自己的需求来进行选择。
UUID(uuid)js 生成的更多相关文章
- 【js  UUID】JS生成UUID 使用
		* 生成UUID * @returns */ function UUID() { var s = []; var hexDigits = "0123456789abcdef"; f ... 
- js生成唯一的uuid
		---恢复内容开始--- 在做项目的时候出现这样的一种情况,需要动态生成唯一的uuid,刚开始我的思路是这样的,我可以根据时间来做,然后出现了下面的思路: var uuid = "cms&q ... 
- UUID介绍与生成的方法
		什么是UUID? UUID是Universally Unique Identifier的缩写,它是在一定的范围内(从特定的名字空间到全球)唯一的机器生成的标识符.UUID具有以下涵义: 经由一定的算法 ... 
- js生成随即字符串
		js生成随即字符串 /* *js生成随即字符串原来如此简单 *toString() radix argument must be between 2 and 36 */ function uuid() ... 
- jquery.qrcode.min.js生成二维码 通过前端实现二维码生成
		主体代码: <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <tit ... 
- 利用scrapy-splash爬取JS生成的动态页面
		目前,为了加速页面的加载速度,页面的很多部分都是用JS生成的,而对于用scrapy爬虫来说就是一个很大的问题,因为scrapy没有JS engine,所以爬取的都是静态页面,对于JS生成的动态页面都无 ... 
- JS生成二维码,允许中文转码
		一.使用jquery-qrcode生成二维码 先简单说一下jquery-qrcode,这个开源的三方库(可以从https://github.com/jeromeetienne/jquery-qrcod ... 
- js生成[n,m]的随机数
		一.预备知识 Math.ceil(); //向上取整. Math.floor(); //向下取整. Math.round(); //四舍五入. Math.random(); //0.0 ~ 1 ... 
- JS生成随机数的各种函数
		第一种方法 /* *@desc:生成随机字符串 *@remark:toString方法可以接收一个基数作为参数的原理,这个基数从2到36封顶.如果不指定,默认基数是10进制 */ function g ... 
- js生成当前时间
		js生成当前时间 var today=new Date(); function itArray(){ this.length=itArray.arguments.length for(var i=0; ... 
随机推荐
- ios ZBar扫二维码奇奇怪怪的错误
			Undefined symbols for architecture armv7: "_CVPixelBufferGetHeight", referenced from: -[ZB ... 
- POJ 2887 Big String(块状链表)
			题目大意 给一个字符串,长度不超过 106,有两种操作: 1. 在第 i 个字符的前面添加一个字符 ch 2. 查询第 k 个位置是什么字符 操作的总数不超过 2000 做法分析 好多不同的做法都可以 ... 
- [LeetCode] Wildcard Matching 字符串匹配,kmp,回溯,dp
			Implement wildcard pattern matching with support for '?' and '*'. '?' Matches any single character. ... 
- JavaScript富应用MVC MVVM框架
			对框架的挑选 Ember.js.Backbone.js.Knockout.js.Spine.js.Batman.js , Angular.js 1. 轻量级的应用选择哪一个会比较好?2. 那一个比较简 ... 
- ruby -- 问题解决(五)页面返回跳转
			今天在做页面跳转的时候,google了下页面跳转的方法, 跳转到上一个页面:redirect_to :back <%= link_to "返回" ,:back %> 这 ... 
- android基础---->JSON数据的解析
			上篇博客,我们谈到了XML两种常用的解析技术,详细可以参见我的博客(android基础---->XMl数据的解析).网络传输另外一种数据格式JSON就是我们今天要讲的,它是比XML体积更小的数据 ... 
- Android上的事件流操作数据库
			最近在浏览某篇有关事件流的文章时,里面提到了数据的流处理,兴趣来了,就想看看能否在Android端实现一个. 根据文章的介绍,将每次数据的变更事件,像是插入,删除或者更新等,记为一个不可变的事件,让数 ... 
- .NET ORM 哪家强
			ORM到底哪家强? 很多人都想知道这个问题,自已也没测试过,只能道听途说. 闲的无聊就将几个ORM拿出来比一比,假如怀疑测试代码有问题可以将它下载下来慢慢研究. 参赛ORM 1.SqlSugar:是一 ... 
- [C#] 语法之Attribute
			在c#中,定义类的成员,可以定义Property称为属性.Attribute就称为特性. 在FCL中,有内置的Attribute.如: Condition[Attribute]:在什么条件可以调用.( ... 
- JavaScript语言知识收藏
			接触Web开发也已经有一段时间了,对javascript的认识也比以前有了更加深入的认识了,所以觉得应该整理一下. 一.JavaScript不支持函数(方法)的重载,用一个例子证明如下: functi ... 
