JavaScript 生成唯一ID的几种方式
更新时间:2021年02月19日 09:13:47 作者:specialCoder
这篇文章主要介绍了JavaScript 生成唯一ID的几种方式,帮助大家更好的理解和使用JavaScript,感兴趣的朋友可以了解下
可行方案
1.生成[0,1)的随机数的Math.random
//我这次运行生成的是:0.5834165740043102 Math.random();
2.获取当前时间戳Date.now
//现在时间戳是1482645606622 Date.now();
3.将10进制转换为其他进制的字符串 Number.toString
//将1482645606622转换成二进制:10101100100110100100100001001000011011110 (1482645606622).toString(2); //转换成16进制:159349090de MongDB中的ObjectID就是24位16进制数 (1482645606622).toString(16); //最大进制支持转为36进制,使用字符是0-9a-z :ix48wvry (1482645606622).toString(36);
改进版本一:随机数 + toString()
1.随机数版本
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString() } //生成一个类似 0.1283460319177394的ID GenNonDuplicateID()
2.随机数版本16进制版本
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString(16) } //函数将生成类似 0.c1615913fa915 的ID GenNonDuplicateID()
3.随机数版本36进制版本
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString(36) } //函数将生成类似 0.hefy7uw6ddzwidkwcmxkzkt9 的ID GenNonDuplicateID()
4.随机数版本36进制版本
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString(36).substr(2) } //函数将生成类似 8dlv9vabygks2cbg1spds4i 的ID GenNonDuplicateID()
总结
优势:使用toString的进制转化可以实现更短的字符串表示更多的范围
缺点:用一个随机数作为ID,随着使用次数的累积,必然会出现相同的两个ID
改进版本二
1.引入时间戳 + 36进制版本
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ let idStr = Date.now().toString(36) idStr += Math.random().toString(36).substr(2) return idStr } //函数将生成类似 ix49sfsnt7514k5wpflyb5l2vtok9y66r 的ID GenNonDuplicateID()
2.引入时间戳 + 36进制版本 + 随机数长度控制
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(randomLength){ let idStr = Date.now().toString(36) idStr += Math.random().toString(36).substr(2,randomLength) return idStr } // GenNonDuplicateID(3) 将生成类似 ix49wl2978w 的ID GenNonDuplicateID(3)
但是,这样生成的ID前面几位总是相同。
3. 引入时间戳 + 随机数前置 36进制 + 随机数长度控制
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(randomLength){ return Number(Math.random().toString().substr(2,randomLength) + Date.now()).toString(36) } //GenNonDuplicateID()将生成 rfmipbs8ag0kgkcogc 类似的ID GenNonDuplicateID()
总结
只使用时间戳,有个能在同一时间多人访问生成的是一样的。加上随机数可以实现唯一。再加上自定义长度,使UUID更灵活。
总结
万能方案:
/** * 生成一个用不重复的ID * @param { Number } randomLength */ function getUuiD(randomLength){ return Number(Math.random().toString().substr(2,randomLength) + Date.now()).toString(36) }
以上就是JavaScript 生成唯一ID的几种方式的详细内容,更多关于JavaScript 生成唯一ID的资料请关注脚本之家其它相关文章!
相关文章
uniapp 手机验证码输入框实现代码(随机数、倒计时、隐藏手机号码中间四位)可以直接使用
这篇文章主要介绍了uniapp 手机验证码输入框(随机数、倒计时、隐藏手机号码中间四位),实现思路通过创建六个正方形的view,然后创建一个数字input,最大输入长度为六位(根据验证码的长度),再将input隐藏掉,获取到的值分别放到六个view中,需要的朋友可以参考下2023-02-02Wordpress ThickBox 添加“查看原图”效果代码
上一次修改了点击图片动作 , 这次添加一个“查看原图”的链接,点击后将在一个新浏览器窗口(或Tab)打开该图片的原始链接地址。2010-12-12
最新评论