首页前端开发JavaScriptJavaScript 生成唯一ID的几种方式

JavaScript 生成唯一ID的几种方式

时间2024-01-31 21:56:02发布访客分类JavaScript浏览1060
导读:收集整理的这篇文章主要介绍了JavaScript 生成唯一ID的几种方式,觉得挺不错的,现在分享给大家,也给大家做个参考。 可行方案1.生成[0,1 的随机数的Math.random//...
收集整理的这篇文章主要介绍了JavaScript 生成唯一ID的几种方式,觉得挺不错的,现在分享给大家,也给大家做个参考。

可行方案

1.生成[0,1)的随机数的Math.random

//我这次运行生成的是:0.5834165740043102 Math.random();
    

2.获取当前时间戳Date.now

//现在时间戳是1482645606622Date.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的IDGenNonDuplicateID()

2.随机数版本16进制版本

/** * 生成一个用不重复的ID */function GenNonDuplicateID(){
 return Math.random().toString(16)}
    //函数将生成类似 0.c1615913fa915 的IDGenNonDuplicateID()

3.随机数版本36进制版本 

/** * 生成一个用不重复的ID */function GenNonDuplicateID(){
 return Math.random().toString(36)}
    //函数将生成类似 0.hefy7uw6ddzwidkwcmxkzkt9 的IDGenNonDuplicateID()

4.随机数版本36进制版本

/** * 生成一个用不重复的ID */function GenNonDuplicateID(){
 return Math.random().toString(36).substr(2)}
    //函数将生成类似 8dlv9vabygks2cbg1spds4i 的IDGenNonDuplicateID()

总结

优势:使用toString的进制转化可以实现更短的字符串表示更多的范围

缺点:用一个随机数作为ID,随着使用次数的累积,必然会出现相同的两个ID

改进版本二

1.引入时间戳 + 36进制版本 

/** * 生成一个用不重复的ID */function GenNonDuplicateID(){
 let idStr = Date.now().toString(36) idStr += Math.random().toString(36).substr(2) return idStr}
    //函数将生成类似 ix49sfsnt7514k5wpflyb5l2vtok9y66r 的IDGenNonDuplicateID()

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 的IDGenNonDuplicateID(3)

但是,这样生成的ID前面几位总是相同。

3. 引入时间戳 + 随机数前置 36进制 + 随机数长度控制

/** * 生成一个用不重复的ID */function GenNonDuplicateID(randomLength){
 return Number(Math.random().toString().substr(2,randomLength) + Date.now()).toString(36)}
    //GenNonDuplicateID()将生成 rfmipbs8ag0kgkcogc 类似的IDGenNonDuplicateID()

总结

只使用时间戳,有个能在同一时间多人访问生成的是一样的。加上随机数可以实现唯一。再加上自定义长度,使UUID更灵活。

总结

万能方案:

/** * 生成一个用不重复的ID * @param {
 Number }
 randomLength  */function getUuiD(randomLength){
 return Number(Math.random().toString().substr(2,randomLength) + Date.now()).toString(36)}
    

以上就是JavaScript 生成唯一ID的几种方式的详细内容,更多关于JavaScript 生成唯一ID的资料请关注其它相关文章!

您可能感兴趣的文章:
  • Javascript生成全局唯一标识符(GUID,UUID)的方法
  • extjs每个组件要设置唯一的ID否则会出错

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: JavaScript 实现继承的几种方式下一篇:JavaScript实现打字游戏猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: JavaScript 生成唯一ID的几种方式
本文地址: https://pptw.com/jishu/594528.html
JavaScript实现打字游戏 react项目从新建到部署的实现示例

游客 回复需填写必要信息