JavaScript如何生成唯一id?你知道哪些方法?
Admin 2021-05-17 群英技术资讯 704 次浏览
JavaScript如何生成唯一id?有哪些方法?很多刚接触JavaScript的朋友,可能对于生成唯一ID的方式不是很了解,因此,下面小编就给大家分享一些JavaScript生成唯一id方法,需要的朋友可以参考。
//我这次运行生成的是:0.5834165740043102 Math.random();
//现在时间戳是1482645606622 Date.now();
//将1482645606622转换成二进制:10101100100110100100100001001000011011110 (1482645606622).toString(2); //转换成16进制:159349090de MongDB中的ObjectID就是24位16进制数 (1482645606622).toString(16); //最大进制支持转为36进制,使用字符是0-9a-z :ix48wvry (1482645606622).toString(36);
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString() } //生成一个类似 0.1283460319177394的ID GenNonDuplicateID()
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString(16) } //函数将生成类似 0.c1615913fa915 的ID GenNonDuplicateID()
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString(36) } //函数将生成类似 0.hefy7uw6ddzwidkwcmxkzkt9 的ID GenNonDuplicateID()
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ return Math.random().toString(36).substr(2) } //函数将生成类似 8dlv9vabygks2cbg1spds4i 的ID GenNonDuplicateID()
优势:使用toString的进制转化可以实现更短的字符串表示更多的范围
缺点:用一个随机数作为ID,随着使用次数的累积,必然会出现相同的两个ID
/** * 生成一个用不重复的ID */ function GenNonDuplicateID(){ let idStr = Date.now().toString(36) idStr += Math.random().toString(36).substr(2) return idStr } //函数将生成类似 ix49sfsnt7514k5wpflyb5l2vtok9y66r 的ID GenNonDuplicateID()
/** * 生成一个用不重复的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前面几位总是相同。
/** * 生成一个用不重复的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内容大家可以继续关注其他相关文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
目录自定义组件@click点击失效问题描述原因分析问题解决@click不起作用,同时报错自定义组件@click点击失效问题描述自定义组件在使无法,无法绑定原vue文件内的原生click事件原因分析根据查询vue官方文档,得知click事件作用于组件内部,如果组件内没有写click事件,便会无响应。问题解决1.参照官方文
这篇文章主要介绍了JavaScript Dom对象的操作,文张以浏览器网页就是一个Dom树形结构做为核心,然后根据核心进行更新Dom节点、获得Dom节点、删除一个Dom节点、添加一个新的节点操作,下面文章是详细内容,需要的朋友可以参考以下
本篇文章给大家带来了关于JavaScript闭包的学习笔记,其中包括了闭包与方法栈以及闭包的作用,希望对大家有帮助。
React路由传参方法有哪些?我们知道React中传参方式有很多,通过路由传参的方式也是必不可少的一种。因此,这篇文章就给大家分享一下React路由传参方法及实现,感兴趣的朋友就继续往下看吧。
这篇文章给大家分享的是有关js中class怎么用的内容。js中class的用法是比较重要的内容,因此分享给大家做个参考,接下来一起跟随小编看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008