zoukankan      html  css  js  c++  java
  • 前端生成全球唯一码GUID

    function GUID() { 

     this.date = new Date();  //先new一个时间备用

    GUID.prototype.newGUID = function () {
    this.date = new Date();
    var guidStr = '';
    sexadecimalDate = this.hexadecimal(this.getGUIDDate(), 16);
    sexadecimalTime = this.hexadecimal(this.getGUIDTime(), 16);
    for (var i = 0; i < 9; i++) {
    guidStr += Math.floor(Math.random() * 16).toString(16);
    }
    guidStr += sexadecimalDate;
    guidStr += sexadecimalTime;
    while (guidStr.length < 32) {
    guidStr += Math.floor(Math.random() * 16).toString(16);
    }
    return this.formatGUID(guidStr);
    }

    获取当前日期的GUID格式,即8位数的日期:

    GUID.prototype.getGUIDDate = function () {
    return this.date.getFullYear() + this.addZero(this.date.getMonth() + 1) + this.addZero(this.date.getDay());
    }

    获取当前时间的GUID格式,即8位数的时间,包括毫秒,毫秒为2位数:12300933

    返回GUID日期格式的字条串

    GUID.prototype.getGUIDTime = function () {
    return this.addZero(this.date.getHours()) + this.addZero(this.date.getMinutes()) + this.addZero(this.date.getSeconds()) + this.addZero(parseInt(this.date.getMilliseconds() / 10));
    }

    为一位数的正整数前面添加0,如果是可以转成非NaN数字的字符串也可以实现

    参数表示准备再前面添加0的数字或可以转换成数字的字符串

    如果符合条件,返回添加0后的字条串类型,否则返回自身的字符串

    GUID.prototype.addZero = function (num) {
    if (Number(num).toString() != 'NaN' && num >= 0 && num < 10) {
    return '0' + Math.floor(num);
    } else {
    return num.toString();
    }
    }

    将y进制的数值,转换为x进制的数值

    1个参数表示欲转换的数值;第2个参数表示欲转换的进制;第3个参数可选,表示当前的进制数,如不写则为10

    返回转换后的字符串

    GUID.prototype.hexadecimal = function (num, x, y) {
    if (y != undefined) {
    return parseInt(num.toString(), y).toString(x);
    } else {
    return parseInt(num.toString()).toString(x);
    }
    }

    格式化32位的字符串为GUID模式的字符串

    第1个参数表示32位的字符串
       标准GUID格式的字符串

    GUID.prototype.formatGUID = function (guidStr) {
    var str1 = guidStr.slice(0, 8) + '-',
    str2 = guidStr.slice(8, 12) + '-',
    str3 = guidStr.slice(12, 16) + '-',
    str4 = guidStr.slice(16, 20) + '-',
    str5 = guidStr.slice(20);
    return str1 + str2 + str3 + str4 + str5;
    }

  • 相关阅读:
    Cesium原理篇:4Web Workers剖析(2)
    Cesium原理篇:4Web Workers剖析
    Cesium原理篇:3最长的一帧之地形(1)
    Cesium原理篇:2最长的一帧之网格划分
    Cesium原理篇:1最长的一帧之渲染调度
    CSS3火焰文字特效制作教程
    一款非常棒的纯CSS3 3D菜单演示及制作教程
    jQuery/CSS3类似阿里巴巴的商品导航菜单实现教程
    CSS3 3D立方体翻转菜单实现教程
    强大!HTML5 3D美女图片旋转实现教程
  • 原文地址:https://www.cnblogs.com/pang572936554/p/7079184.html
Copyright © 2011-2022 走看看