如何使用javascript计算下一个修订号

How to use javascript to calculate the next revision number

本文关键字:下一个 计算 何使用 javascript      更新时间:2023-09-26

我的应用程序中有一个修订号属性,它只是一个字符串。我需要传入当前值,计算下一个有效值并返回。

以下是有效的进展:

.A
.B
.C
0
0.A
0.B
1
1.A
etc

忘记全部数字吧,这是其他地方控制的。这只适用于有周期的。限制是:

  • 第一个分量总是一个数字(或者什么都不是)
  • 然后是一段时间
  • 然后是一个字母,不包括I和O(因为它们类似于1和0),一旦你到达Z,它就应该变成AA、AB、AC。。。,ZZ

所以

If I pass in .A it should return .B
If I pass in 1.H it should pass back 1.J
If I pass in 1.Z it should pass back 1.AA

如有任何帮助,我们将不胜感激。

这是我所拥有的——我只是不知道如何"增加"字母部分:

function calcNextRev(currentRev)
{
var revParts = currentRev.split(".");
var majorRev = revParts[0];
var currentMinorRev = revParts[1];
???
return majorRev + "." + newMinorRev;
}

试试这个:

(此处演示)

var alfab=[A','B','C','D','E','F','G','H','J','K','L','M','N','p','Q','R','S','T','U','V','W','Y','Z';var currentRev="0.AZ";var结果;

function calcNextRev(currentRev) {
var newMinorRev;
var revParts = currentRev.split(".");
var majorRev = revParts[0];
var currentMinorRev = revParts[1];
//Case string is 1 letter long
if (currentMinorRev.length == 1) {
    for (i = 0; i < alfab.length; i++) {
        if (currentMinorRev == alfab[i]) {
            if (i == alfab.length - 1) {
                newMinorRev = alfab[0] + alfab[0];
            } else {
                var ii = i + 1;
                newMinorRev = alfab[ii];
            }
        }
    }
}
//Case string is more than one letter long
if (currentMinorRev.length > 1) {
    var currentMinorRev2 = currentMinorRev.split("");
    var l = currentMinorRev2.length - 1;
    for (o = 0; o < alfab.length; o++) {
        if (currentMinorRev2[l] == alfab[o] && o == alfab.length - 1) 
        {
            var currentalias = currentMinorRev2;
            currentalias[l] = alfab[0];
            currentalias.push(alfab[0]);
            newMinorRev = currentalias.join('');
        } 
        if (currentMinorRev2[l] == alfab[o] && o != alfab.length - 1) 
        {
            var xo = o + 1;
            var currentalias = currentMinorRev2;
            currentalias[l] = alfab[xo];
            newMinorRev = currentalias.join('');
            o++;
        }
    }
};
result = majorRev + "." + newMinorRev;
return result;
}
alert(calcNextRev(currentRev));

本质上,您所做的是计数,尽管以24为基数,并使用数字ABCDEFGHJKLMNPQRSTUVWXYZ而不是"正常"0123456789ABCDEFGHIJKLMNO。因此,我们将使用JavaScript鲜为人知的处理非10进制数字的能力,即parseInt(value,base)value.toString(base)

var letters = "ABCDEFGHJKLMNPQRSTUVWXYZ".split(""), 
    base24_to_letters_map = {}, 
    letters_to_base24_map = {};
// Build maps from base 24 digits to desired range of letters and vice versa
for (var i=0; i<24; i++) {
    base24_to_letters_map[i.toString(24)] = letters[i];
    letters_to_base24_map[letters[i]] = i.toString(24).toUpperCase();
}
// Convert each digit in "val" based on "map"
function convert (val, map) {
    return val.replace(/[0-9A-Z]/g, function(chr) { return map[chr]; });
}
function increment (version) {
    var base24, number;
    base24 = convert (version, letters_to_base24_map);  // convert "BJ" to "1A"
    number = parseInt (base24, 24);                     // convert "1A" to 34
    number++;                                           // increment
    base24 = number.toString (24);                      // convert 35 to "1B"
    version = convert (base24, base24_to_letters_map);  // convert 1B to BK
    return version;
}

这也给你三个字母和更多的版本号"免费";"ZZ"将变为"AAA"。此外,它还允许您轻松地向前或向后跳任意数量的版本。

处理前导数字版本号:

full_version.replace(/[A-Z][A-Z]?/, function (letter_portion) {
    return increment (letter_portion);
});