Как получить следующую букву алфавита в Javascript? - PullRequest
29 голосов
/ 13 февраля 2010

Я создаю автозаполнение, которое выполняет поиск в представлении CouchDB.

Мне нужно иметь возможность взять последний символ входной строки и заменить последний символ следующей буквой английского алфавита. (Здесь нет необходимости в i18n)

Например:

  • Строка ввода = "b"
  • startkey = "b"
  • endkey = "c"

OR

  • Строка ввода = "foo"
  • startkey = "foo"
  • endkey = "fop"

(если вам интересно, я обязательно включу опцию inclusive_end=false, чтобы этот дополнительный символ не испортил мой набор результатов)


Вопрос

  • Есть ли в Javascript функция, которая может просто получить следующую букву алфавита?
  • Или мне просто нужно смириться с этим и выполнить собственную причудливую функцию с базовой строкой, такой как "abc ... xyz" и indexOf()?

Ответы [ 4 ]

41 голосов
/ 13 февраля 2010
my_string.substring(0, my_string.length - 1)
      + String.fromCharCode(my_string.charCodeAt(my_string.length - 1) + 1)
25 голосов
/ 13 февраля 2010

// Это вернет A для Z и a для z.

function nextLetter(s){
    return s.replace(/([a-zA-Z])[^a-zA-Z]*$/, function(a){
        var c= a.charCodeAt(0);
        switch(c){
            case 90: return 'A';
            case 122: return 'a';
            default: return String.fromCharCode(++c);
        }
    });
}
15 голосов
/ 21 июля 2015

Более полное решение, которое получает следующую букву в зависимости от того, как MS Excel нумерует столбцы ... A B C ... Y Z AA AB ... AZ BA ... ZZ AAA

Это работает с маленькими буквами, но вы можете легко расширить его и для заглавных букв.

getNextKey = function(key) {
  if (key === 'Z' || key === 'z') {
    return String.fromCharCode(key.charCodeAt() - 25) + String.fromCharCode(key.charCodeAt() - 25); // AA or aa
  } else {
    var lastChar = key.slice(-1);
    var sub = key.slice(0, -1);
    if (lastChar === 'Z' || lastChar === 'z') {
      // If a string of length > 1 ends in Z/z,
      // increment the string (excluding the last Z/z) recursively,
      // and append A/a (depending on casing) to it
      return getNextKey(sub) + String.fromCharCode(lastChar.charCodeAt() - 25);
    } else {
      // (take till last char) append with (increment last char)
      return sub + String.fromCharCode(lastChar.charCodeAt() + 1);
    }
  }
  return key;
};
5 голосов
/ 05 ноября 2017

Вот функция, которая делает то же самое (за исключением только заглавных букв, но это легко изменить), но использует slice только один раз и является итеративной, а не рекурсивной. В быстром тесте это примерно в 4 раза быстрее (что актуально только в том случае, если вы действительно интенсивно его используете!).

function nextString(str) {
    if (! str)
        return 'A'  // return 'A' if str is empty or null

    let tail = ''
    let i = str.length -1
    let char = str[i]
    // find the index of the first character from the right that is not a 'Z'
    while (char === 'Z' && i > 0) {
        i--
        char = str[i]
        tail = 'A' + tail   // tail contains a string of 'A'
    }
    if (char === 'Z')   // the string was made only of 'Z'
        return 'AA' + tail
    // increment the character that was not a 'Z'
    return str.slice(0, i) + String.fromCharCode(char.charCodeAt(0) + 1) + tail

}

...