JavaScript生成GUID的方法

 
function guid() {
 function S4() {
    function S4() {
 return (((1+Math.random())*0x10000)|0).toString(16).substring(1);
       return (((1+Math.random())*0x10000)|0).toString(16).substring(1);
 }
    }
 return (S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4());
    return (S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4());
 }
}

二、生成GUID的方法二

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

三、生成GUID的方法三

 
function uuid() {
 var s = [];
    var s = [];
 var hexDigits = "0123456789abcdef";
    var hexDigits = "0123456789abcdef";
 for (var i = 0; i < 36; i++) {
    for (var i = 0; i < 36; i++) {
 s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
        s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
 }
    }
 s[14] = "4";  // bits 12-15 of the time_hi_and_version field to 0010
    s[14] = "4";  // bits 12-15 of the time_hi_and_version field to 0010
 s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1);  // bits 6-7 of the clock_seq_hi_and_reserved to 01
    s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1);  // bits 6-7 of the clock_seq_hi_and_reserved to 01
 s[8] = s[13] = s[18] = s[23] = "-";
    s[8] = s[13] = s[18] = s[23] = "-";

 var uuid = s.join("");
    var uuid = s.join("");
 return uuid;
    return uuid;
 }
}

四、生成GUID的方法四

 
function uuid(len, radix) {
 var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');
    var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');
 var uuid = [], i;
    var uuid = [], i;
 radix = radix || chars.length;
    radix = radix || chars.length;

 if (len) {
    if (len) {
 // Compact form
      // Compact form
 for (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random()*radix];
      for (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random()*radix];
 } else {
    } else {
 // rfc4122, version 4 form
      // rfc4122, version 4 form
 var r;
      var r;

 // rfc4122 requires these characters
      // rfc4122 requires these characters
 uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';
      uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';
 uuid[14] = '4';
      uuid[14] = '4';

 // Fill in random data.  At i==19 set the high bits of clock sequence as
      // Fill in random data.  At i==19 set the high bits of clock sequence as
 // per rfc4122, sec. 4.1.5
      // per rfc4122, sec. 4.1.5
 for (i = 0; i < 36; i++) {
      for (i = 0; i < 36; i++) {
 if (!uuid[i]) {
        if (!uuid[i]) {
 r = 0 | Math.random()*16;
          r = 0 | Math.random()*16;
 uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];
          uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];
 }
        }
 }
      }
 }
    }

 return uuid.join('');
    return uuid.join('');
 }
}

JavaScript生成GUID的方法的更多相关文章
- 原生JavaScript生成GUID的实现
		GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的.通常平台会提供生成GUID的API.生成算法很有意思,用到了以太网卡地址.纳秒级时间.芯片ID码和许多可 ... 
- Javascript生成GUID
		GUID(全球唯一标识)是微软使用的一个术语,由一个特定的算法,给某一个实体,如Word文档,创建一个唯一的标识,GUID值就是这个唯一的标识码.除了.Net有专门的方法生成外,JS也可以生成GUID ... 
- javascript生成GUID的代码
		<script type="text/javascript"> var Guid = function(){}; Guid.prototype = { S4:funct ... 
- Javascript生成GUID算法
		var GUID = { date: new Date(), /* 生成GUID码 */ newGUID: function () { this.date = new Date(); var guid ... 
- [转] JavaScript生成GUID的算法
		原文地址: http://www.cnblogs.com/snandy/p/3261754.html 全局唯一标识符(GUID,Globally Unique Identifier)也称作 UUID( ... 
- JavaScript生成GUID的算法
		全局唯一标识符(GUID,Globally Unique Identifier)也称作 UUID(Universally Unique IDentifier) . GUID是一种由算法生成的二进制长度 ... 
- JavaScript生成GUID的多种算法小结
		全局唯一标识符(GUID,Globally Unique Identifier)也称作 UUID(Universally Unique IDentifier) . GUID是一种由算法生成的二进制长度 ... 
- JavaScript 生成Guid函数
		//获取长度为32的Guid function getGuid32() { var rt_str = String.fromCharCode(65 + Math.floor(Math.random() ... 
- 在C#中生成GUID的方法
		var guid = Guid.NewGuid();Debug.WriteLine(guid.ToString()); //1f3c6041-c68f-4ab3-ae19-f66f541e3209 ... 
随机推荐
- [leetcode DP]63. Unique Paths II
			Follow up for "Unique Paths": Now consider if some obstacles are added to the grids. How m ... 
- JS Function Arguments
			Function arguments在ECMAScript中的行为并不像其他大多数语言中的函数参数. 在ECMAScript中,function 并不关心有多少个参数传入函数中,也不关心传入参数的数据 ... 
- 【差分约束系统/SPFA】POJ3169-Layout
			[题目大意] n头牛从小到大排,它们之间某些距离不能大于一个值,某些距离不能小于一个值,求第一头牛和第N头牛之间距离的最大值. [思路] 由题意可以得到以下不等式d[AL]+DL≥d[BL]:d[BD ... 
- [CF183D]T-shirt
			[CF183D]T-shirt 题目大意: 有\(n(n\le3000)\)个人和\(m(m\le300)\)种T恤,每个人都有一种喜欢的T恤,你知道每个人喜欢每种T恤的概率\(p_{i,j}\). ... 
- SpringBoot+SpringSecurity+Thymeleaf认证失败返回错误信息踩坑记录
			Spring boot +Spring Security + Thymeleaf认证失败返回错误信息踩坑记录 步入8102年,现在企业开发追求快速,Springboot以多种优秀特性引领潮流,在众多使 ... 
- SLF4J versions 1.4.0 and later requires log4j 1.2.12 or later 终极解决
			http://blog.sina.com.cn/s/blog_54eb26870100uynj.html 到SLF4J官方网站:http://www.slf4j.org/codes.html#log4 ... 
- word-ladder总结
			title: word ladder总结 categories: LeetCode tags: 算法 LeetCode comments: true date: 2016-10-16 09:42:30 ... 
- Elasticsearch快速入门案例
			写在前面的话:读书破万卷,编码如有神-------------------------------------------------------------------- 参考内容: <Ela ... 
- centos7安装kafka_2.11-1.0.0 新手入门
			系统环境 1.操作系统:64位CentOS Linux release 7.2.1511 (Core) 2.jdk版本:1.8.0_121 3.zookeeper版本:zookeeper-3.4.9. ... 
- PowerDesigner设置唯一约束/唯一索引/唯一键
			注意:还需要设置unique约束,也是在这个界面. 参考: https://blog.csdn.net/cnham/article/details/6676650 https://blog.csdn. ... 
