這篇文章主要介紹了怎么使用javascript雪花算法生成隨機ID的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇怎么使用javascript雪花算法生成隨機ID文章都會有所收獲,下面我們一起來看看吧。
成都創(chuàng)新互聯公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網站建設、網站制作、企業(yè)官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯網時代的饒平網站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!
1、snowflake-id插件
import SnowflakeId from "snowflake-id"; const guid = num => { const id= new SnowflakeId(); return id.generate(); };
2、原生使用
var Snowflake = /** @class */ (function() { function Snowflake(_workerId, _dataCenterId, _sequence) { this.twepoch = 1288834974657n; //this.twepoch = 0n; this.workerIdBits = 5n; this.dataCenterIdBits = 5n; this.maxWrokerId = -1n ^ (-1n << this.workerIdBits); // 值為:31 this.maxDataCenterId = -1n ^ (-1n << this.dataCenterIdBits); // 值為:31 this.sequenceBits = 12n; this.workerIdShift = this.sequenceBits; // 值為:12 this.dataCenterIdShift = this.sequenceBits + this.workerIdBits; // 值為:17 this.timestampLeftShift = this.sequenceBits + this.workerIdBits + this.dataCenterIdBits; // 值為:22 this.sequenceMask = -1n ^ (-1n << this.sequenceBits); // 值為:4095 this.lastTimestamp = -1n; //設置默認值,從環(huán)境變量取 this.workerId = 1n; this.dataCenterId = 1n; this.sequence = 0n; if(this.workerId > this.maxWrokerId || this.workerId < 0) { thrownew Error('_workerId must max than 0 and small than maxWrokerId-[' + this.maxWrokerId + ']'); } if(this.dataCenterId > this.maxDataCenterId || this.dataCenterId < 0) { thrownew Error('_dataCenterId must max than 0 and small than maxDataCenterId-[' + this.maxDataCenterId + ']'); } this.workerId = BigInt(_workerId); this.dataCenterId = BigInt(_dataCenterId); this.sequence = BigInt(_sequence); } Snowflake.prototype.tilNextMillis = function(lastTimestamp) { var timestamp = this.timeGen(); while(timestamp <= lastTimestamp) { timestamp = this.timeGen(); } return BigInt(timestamp); }; Snowflake.prototype.timeGen = function() { return BigInt(Date.now()); }; Snowflake.prototype.nextId = function() { var timestamp = this.timeGen(); if(timestamp < this.lastTimestamp) { thrownew Error('Clock moved backwards. Refusing to generate id for ' + (this.lastTimestamp - timestamp)); } if(this.lastTimestamp === timestamp) { this.sequence = (this.sequence + 1n) & this.sequenceMask; if(this.sequence === 0n) { timestamp = this.tilNextMillis(this.lastTimestamp); } } else { this.sequence = 0n; } this.lastTimestamp = timestamp; return((timestamp - this.twepoch) << this.timestampLeftShift) | (this.dataCenterId << this.dataCenterIdShift) | (this.workerId << this.workerIdShift) | this.sequence; }; return Snowflake; }()); console.log(new Snowflake(1n, 1n, 0n).nextId()); //1141531990672150528n
控制臺輸出1141531990672150528n為bigint格式, .toString()轉為字符串格式即可
3、ES6使用
import bigInt from "big-integer"; const guid = () => { const Snowflake = /** @class */ (function() { function Snowflake(_workerId, _dataCenterId, _sequence) { // this.twepoch = 1288834974657; this.twepoch = 0; this.workerIdBits = 5; this.dataCenterIdBits = 5; this.maxWrokerId = -1 ^ (-1 << this.workerIdBits); // 值為:31 this.maxDataCenterId = -1 ^ (-1 << this.dataCenterIdBits); // 值為:31 this.sequenceBits = 12; this.workerIdShift = this.sequenceBits; // 值為:12 this.dataCenterIdShift = this.sequenceBits + this.workerIdBits; // 值為:17 this.timestampLeftShift = this.sequenceBits + this.workerIdBits + this.dataCenterIdBits; // 值為:22 this.sequenceMask = -1 ^ (-1 << this.sequenceBits); // 值為:4095 this.lastTimestamp = -1; //設置默認值,從環(huán)境變量取 this.workerId = 1; this.dataCenterId = 1; this.sequence = 0; if (this.workerId > this.maxWrokerId || this.workerId < 0) { throw new Error( 'config.worker_id must max than 0 and small than maxWrokerId-[' + this.maxWrokerId + ']' ); } if (this.dataCenterId > this.maxDataCenterId || this.dataCenterId < 0) { throw new Error( 'config.data_center_id must max than 0 and small than maxDataCenterId-[' + this.maxDataCenterId + ']' ); } this.workerId = _workerId; this.dataCenterId = _dataCenterId; this.sequence = _sequence; } Snowflake.prototype.tilNextMillis = function(lastTimestamp) { var timestamp = this.timeGen(); while (timestamp <= lastTimestamp) { timestamp = this.timeGen(); } return timestamp; }; Snowflake.prototype.timeGen = function() { //new Date().getTime() === Date.now() return Date.now(); }; Snowflake.prototype.nextId = function() { var timestamp = this.timeGen(); if (timestamp < this.lastTimestamp) { throw new Error( 'Clock moved backwards. Refusing to generate id for ' + (this.lastTimestamp - timestamp) ); } if (this.lastTimestamp === timestamp) { this.sequence = (this.sequence + 1) & this.sequenceMask; if (this.sequence === 0) { timestamp = this.tilNextMillis(this.lastTimestamp); } } else { this.sequence = 0; } this.lastTimestamp = timestamp; var shiftNum = (this.dataCenterId << this.dataCenterIdShift) | (this.workerId << this.workerIdShift) | this.sequence; // dataCenterId:1,workerId:1,sequence:0 shiftNum:135168 var nfirst = new bigInt(String(timestamp - this.twepoch), 10); nfirst = nfirst.shiftLeft(this.timestampLeftShift); var nnextId = nfirst.or(new bigInt(String(shiftNum), 10)).toString(10); return nnextId; }; return Snowflake; })(); return new Snowflake(1, 1, 0).nextId(); };
guid()即可調用
4、多次重復調用出現一樣id的bug
console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime()); console.log(guid(), new Date().getTime());
修改如下
import SnowflakeId from "snowflake-id"; const guid = num => { const snowflake = new SnowflakeId(); let arr = []; for (let i = 0; i < num; i++) { arr.push(snowflake.generate()); } return num ? arr : snowflake.generate(); };
單個調用 guid()
n個調用 guid(n)
1、js屬于一種解釋性腳本語言;
2、在絕大多數瀏覽器的支持下,js可以在多種平臺下運行,擁有著跨平臺特性;
3、js屬于一種弱類型腳本語言,對使用的數據類型未做出嚴格的要求,能夠進行類型轉換,簡單又容易上手;
4、js語言安全性高,只能通過瀏覽器實現信息瀏覽或動態(tài)交互,從而有效地防止數據的丟失;
5、基于對象的腳本語言,js不僅可以創(chuàng)建對象,也能使用現有的對象。
關于“怎么使用javascript雪花算法生成隨機ID”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“怎么使用javascript雪花算法生成隨機ID”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道。