js生成唯一标识id的几种方法

  在开发中偶尔会遇到需要生成唯一id的时候,比如对数组的任意一项进行多次增删改,这时就需要给每一项添加唯一标识符来加以区分。
  以下总结了几种生成唯一标识的方法,仅供参考。

方法一

说明: 生成标准的uuid,且方法最简单

function uuid() {
    return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
        var r = Math.random() * 16 | 0,
            v = c == 'x' ? r : (r & 0x3 | 0x8);
        return v.toString(16);
    });
}
console.log( uuid() );    // 12c96135-d4b6-488f-ba1d-449b27851e0b

结果如下:
js生成唯一标识id的几种方法_第1张图片

方法一扩展

说明: 生成标准的uuid,且使用了随机种子,比方法一要好

function uuid() {
    var d = new Date().getTime();
    if (window.performance && typeof window.performance.now === "function") {
        d += performance.now(); //use high-precision timer if available
    }
    var uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
        var r = (d + Math.random() * 16) % 16 | 0;    // d是随机种子
        d = Math.floor(d / 16);
        return (c == 'x' ? r : (r & 0x3 | 0x8)).toString(16);
    });
    return uuid;
}
console.log( uuid() ) ;   //  826fe4be-631c-4a63-83e9-96a788e8a569

结果如下:
js生成唯一标识id的几种方法_第2张图片

方法二

说明: 生成了不太规范的唯一标识,但是平时使用是最简便的

var uuid = new Date().getTime() + Math.random().toString(36).substr(2);
console.log( uuid );   // 1590753224242oqgomgkv7tp

结果如下:
在这里插入图片描述

方法二扩展

说明: 比方法二看起来规范些,但是需要一个格式化时间的函数。

function formatDateTime() {
    var date = new Date();
    var y = date.getFullYear();
    var m = date.getMonth() + 1;
    m = m < 10 ? ('0' + m) : m;
    var d = date.getDate();
    d = d < 10 ? ('0' + d) : d;
    var h = date.getHours();
    var minute = date.getMinutes();
    var second = date.getSeconds();
    return y + m + d + h + minute + second;
}

var uuid = formatDateTime() + Math.random().toString(36).substr(2);
console.log(uuid);   // 20200529195844692wbkvn5l

结果如下:
js生成唯一标识id的几种方法_第3张图片



以下方法均为借鉴别人的,有需要的可以使用

方法四

说明: 借鉴别人的,我也没看太明白

function uuid() {
    var s = [];
    var hexDigits = "0123456789abcdef";
    for (var i = 0; i < 36; i++) {
        s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
    }
    s[14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010
    s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01
    s[8] = s[13] = s[18] = s[23] = "-";

    var uuid = s.join("");
    return uuid;
}
console.log( uuid() ) ;    // 337f459e-7d36-4cb4-838e-09f5fe7b3769

结果如下:
js生成唯一标识id的几种方法_第4张图片

方法五

function uuid2() {
    function S4() {
        return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1);
    }
    return (S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4());
}
console.log( uuid2() );     // 384b0ee9-d334-2beb-0a00-e2026ac40e40

结果如下:
js生成唯一标识id的几种方法_第5张图片

方法六

/*
    指定长度和基数
*/
function uuid3(len, radix) {
    var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');
    var uuid = [],
        i;
    radix = radix || chars.length;

    if (len) {
        // Compact form
        for (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random() * radix];
    } else {
        // rfc4122, version 4 form
        var r;

        // rfc4122 requires these characters
        uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';
        uuid[14] = '4';

        // Fill in random data.  At i==19 set the high bits of clock sequence as
        // per rfc4122, sec. 4.1.5
        for (i = 0; i < 36; i++) {
            if (!uuid[i]) {
                r = 0 | Math.random() * 16;
                uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];
            }
        }
    }

    return uuid.join('');
}

console.log( uuid3() );     //  2089EC65-DB7F-498D-910D-2B3F3BB585E8

结果如下:
js生成唯一标识id的几种方法_第6张图片
其他方法还可参照 https://www.cnblogs.com/yeminglong/p/6249077.html

你可能感兴趣的:(javascript)