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;
    }

  • 相关阅读:
    网络流之转换为对偶图
    BZOJ 1051: [HAOI2006]受欢迎的牛(SCC)
    BZOJ[HNOI2005]狡猾的商人(差分约束)
    BZOJ [ZJOI2007]矩阵游戏(二分图匹配)
    BZOJ 1191: [HNOI2006]超级英雄Hero(二分图匹配)
    BZOJ 1270: [BeijingWc2008]雷涛的小猫(DP)
    BZOJ 1303: [CQOI2009]中位数图
    BZOJ [HNOI2006]鬼谷子的钱袋
    BZOJ1002 [FJOI2007]轮状病毒(最小生成树计数)
    A* 算法讲解
  • 原文地址:https://www.cnblogs.com/pang572936554/p/7079184.html
Copyright © 2011-2022 走看看