原生JavaScript生成GUID的实现

  GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成GUID的API。生成算法很有意思,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。GUID的唯一缺陷在于生成的结果串会比较大。

  GUID的格式为:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx

  大家都知道GUID在前端开发中用处不大,但如果需要插入某个ID,并且这个ID与后台对应等其它需要GUID的操作时,为了方便,我们还是可以生成一个GUID的。

  一般在sql、java、C#等后台或数据库语言中生成GUID都很简单,而前端没有直接生成GUID的方法,只能自己手写一个。但由于GUID需要获取以太网卡的地址、以及纳秒级的时间等数字。而前端获取到这些信息比较困难(知道的童鞋请一定告诉我),而我们可以模拟实现生成GUID,代码如下:

 1 /*
 2  * 功能:生成一个GUID码,其中GUID以14个以下的日期时间及18个以上的16进制随机数组成,GUID存在一定的重复概率,但重复概率极低,理论上重复概率为每10ms有1/(16^18),即16的18次方分之1,重复概率低至可忽略不计
 3  * 免责声明:此代码为作者学习专用,如在使用者在使用过程中因代码问题造成的损失,与作者没有任何关系
 4  * 日期:2014年9月4日
 5  * 作者:wyc
 6  * http://www.cnblogs.com/wuyuchang
 7  */
 8
 9
10 function GUID() {
11     this.date = new Date();
12
13     /* 判断是否初始化过,如果初始化过以下代码,则以下代码将不再执行,实际中只执行一次 */
14     if (typeof this.newGUID != ‘function‘) {
15
16         /* 生成GUID码 */
17         GUID.prototype.newGUID = function() {
18             this.date = new Date();
19             var guidStr = ‘‘;
20                 sexadecimalDate = this.hexadecimal(this.getGUIDDate(), 16);
21                 sexadecimalTime = this.hexadecimal(this.getGUIDTime(), 16);
22             for (var i = 0; i < 9; i++) {
23                 guidStr += Math.floor(Math.random()*16).toString(16);
24             }
25             guidStr += sexadecimalDate;
26             guidStr += sexadecimalTime;
27             while(guidStr.length < 32) {
28                 guidStr += Math.floor(Math.random()*16).toString(16);
29             }
30             return this.formatGUID(guidStr);
31         }
32
33         /*
34          * 功能:获取当前日期的GUID格式,即8位数的日期:19700101
35          * 返回值:返回GUID日期格式的字条串
36          */
37         GUID.prototype.getGUIDDate = function() {
38             return this.date.getFullYear() + this.addZero(this.date.getMonth() + 1) + this.addZero(this.date.getDay());
39         }
40
41         /*
42          * 功能:获取当前时间的GUID格式,即8位数的时间,包括毫秒,毫秒为2位数:12300933
43          * 返回值:返回GUID日期格式的字条串
44          */
45         GUID.prototype.getGUIDTime = function() {
46             return this.addZero(this.date.getHours()) + this.addZero(this.date.getMinutes()) + this.addZero(this.date.getSeconds()) + this.addZero( parseInt(this.date.getMilliseconds() / 10 ));
47         }
48
49         /*
50          * 功能: 为一位数的正整数前面添加0,如果是可以转成非NaN数字的字符串也可以实现
51          * 参数: 参数表示准备再前面添加0的数字或可以转换成数字的字符串
52          * 返回值: 如果符合条件,返回添加0后的字条串类型,否则返回自身的字符串
53          */
54         GUID.prototype.addZero = function(num) {
55             if (Number(num).toString() != ‘NaN‘ && num >= 0 && num < 10) {
56                 return ‘0‘ + Math.floor(num);
57             } else {
58                 return num.toString();
59             }
60         }
61
62         /*
63          * 功能:将y进制的数值,转换为x进制的数值
64          * 参数:第1个参数表示欲转换的数值;第2个参数表示欲转换的进制;第3个参数可选,表示当前的进制数,如不写则为10
65          * 返回值:返回转换后的字符串
66          */
67         GUID.prototype.hexadecimal = function(num, x, y) {
68             if (y != undefined) {
69                 return parseInt(num.toString(), y).toString(x);
70             } else {
71                 return parseInt(num.toString()).toString(x);
72             }
73         }
74
75         /*
76          * 功能:格式化32位的字符串为GUID模式的字符串
77          * 参数:第1个参数表示32位的字符串
78          * 返回值:标准GUID格式的字符串
79          */
80         GUID.prototype.formatGUID = function(guidStr) {
81             var str1 = guidStr.slice(0, 8) + ‘-‘,
82                 str2 = guidStr.slice(8, 12) + ‘-‘,
83                 str3 =  guidStr.slice(12, 16) + ‘-‘,
84                 str4 = guidStr.slice(16, 20) + ‘-‘,
85                 str5 = guidStr.slice(20);
86             return str1 + str2 + str3 + str4 + str5;
87         }
88     }
89 }

GUID 对象

只需要将其保存在一个JS文件中并引用即可。

  然后我们只需要

  var guid = new GUID();

  alert(guid.newGUID()); 

  即可获取GUID码。

  实现原理很简单,这里只是采用了系统时间与18个以上的十六进制随机数组成,并用系统时间转换为十六进制,这样虽然还是有可能重复,但是重复的概率极低,可忽略不计。

  

  以上为本人写的生成GUID的方法,如有更好的方法可以告诉我,谢谢!

时间: 2024-11-07 01:49:15

原生JavaScript生成GUID的实现的相关文章

Javascript生成GUID

GUID(全球唯一标识)是微软使用的一个术语,由一个特定的算法,给某一个实体,如Word文档,创建一个唯一的标识,GUID值就是这个唯一的标识码.除了.Net有专门的方法生成外,JS也可以生成GUID,一般有两种方式,分别是 方法一: //JS生成GUID函数,类似.net中的NewID(); function S4() { return (((1+Math.random())*0x10000)|0).toString(16).substring(1); } function NewGuid()

通过JavaScript生成GUID

function newGuid(){ var guid = ""; for (var i = 1; i <= 32; i++){ var n = Math.floor(Math.random()*16.0).toString(16); guid += n; if((i==8)||(i==12)||(i==16)||(i==20)) guid += "-"; } return guid; } 通过JavaScript生成GUID

JavaScript生成GUID的方法

一.生成GUID的方法一 JScript 代码   复制 function guid() { function S4() { return (((1+Math.random())*0x10000)|0).toString(16).substring(1); } return (S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4()); } 二.生成GUID的方法二 JSc

[&#36716;] JavaScript&#29983;&#25104;GUID&#30340;&#31639;&#27861;

原文地址: http://www.cnblogs.com/snandy/p/3261754.html 全局唯一标识符(GUID,Globally Unique Identifier)也称作 UUID(Universally Unique IDentifier) 。 GUID是一种由算法生成的二进制长度为128位的数字标识符。GUID 的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中的 x 是 0-9 或 a-f 范围内的一个32位十六进制数。在理想情况下

JavaScript生成GUID的算法

全局唯一标识符(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

使用原生JavaScript实现对select增加option标签并附加value属性

好久没有写原生的东西了,今天写了一个小项目里面包含着option选项,所以我决定使用原生JavaScript动态生成, 本着互联网分享精神,我将本篇文章分享给大家. html代码(就是一个select) <select name="" id="reg-select"></select> json数据 var json = [ { "cc": "86", "code": "C

原生javascript实现Tab切换

tab切换在各大主流页面有广泛的应用,今天来分享一个用原生javascript来实现类似京东购物边栏的TAB.对于正在使用web前端开发(http://www.maiziedu.com/course/web/)网站的朋友,是非常有用的哦. 首先以下是一段边栏HTML框架代码 <body> <div class="wrap"> <div id="left"> <ul id="leftList"> &l

javascript生成表格增删改查 JavaScript动态改变表格单元格内容 动态生成表格 JS获取表格任意单元格 javascript如何动态删除表格某一行

jsp页面表格布局Html代码 <body > <center> <input type="text" value="111" id="mytext"> <table border="1" width="60%" id="mytable"> <tr> <td id="td1">第一行第一列<

原生javascript解析xml文档

之前写过一篇 <javascript/jQuery解析或转换json和xml>链接是http://my.oschina.net/ososchina/blog/343748,这篇博客详细解释了json使用 JSON.js  window.eval() ,jQuery 与字符串互相转换的方法 ,顺便也说了一点jQuery解析xml文档的方法,这里着重论述javascript操作xml. 顺便提一下,今天做项目有一点问题,如何让服务程序接口返回的就是json,而不需要 使用 jQuery.ajax设