Правильный способ расширения в Globalize 1.x

У меня был следующий код для добавления пользовательских функций через Globalize 0.x:

Globalize.parseFloatAcceptDotAndComma =
    function (value, radix, cultureSelector) {
        value = value.replace(Globalize.locale(lang).numberFormat['.'] === '.' ? ',' : '.', Globalize.locale(lang).numberFormat['.']);
                return Globalize.parseFloat.call(this, value, radix, cultureSelector);
}

Поскольку API плагина Globalize 1.x отличается, я хочу знать, как добиться того же результата в новой версии плагина?

Благодарю.

Кстати, я включил этот метод в цепочку "тогда", после "потом" (Globalize.load)" - это правильный путь?

ОБНОВЛЕНИЕ: окончательная рабочая версия - благодаря @rxaviers

    var lang = '@Thread.CurrentThread.CurrentUICulture.Name';

    Promise.all([
      // Core
      fetch('/Scripts/cldr/supplemental/likelySubtags.json'),

      // Date
      fetch('/Scripts/cldr/main/' + lang + '/ca-gregorian.json'),
      fetch('/Scripts/cldr/main/' + lang + '/timeZoneNames.json'),
      fetch('/Scripts/cldr/supplemental/timeData.json'),
      fetch('/Scripts/cldr/supplemental/weekData.json'),

      // Number
      fetch('/Scripts/cldr/main/' + lang + '/numbers.json'),
      fetch('/Scripts/cldr/supplemental/numberingSystems.json')
    ])
    .then(function(responses) {
        return Promise.all(responses.map(function(response) {
            return response.json();
        }));
    })
    .then(Globalize.load)
    .then(function () {
            Globalize.parseFloatAcceptDotAndComma =
            Globalize.prototype.parseFloatAcceptDotAndComma = function(value, options) {
            // Assert that value and options are valid.
            // Assert that this.cldr is present

            if (value.indexOf('.') >= 0 && value.indexOf(',') >= 0) {
                throw new Error('Both separators are present');
            }

            value = value.replace(/[,.]/, this.cldr.main('numbers/symbols-numberSystem-latn/decimal'));
            return this.parseNumber(value, options);
        }
    })
    .then(function() { Globalize.locale(lang); });

1 ответ

Решение

Обратите внимание, что ваше решение не поддерживает арабский и другие языки, в которых используются цифры, отличные от латинского. Поэтому я не рекомендую это. Я считаю, что должен быть лучший алгоритм, чем этот.

В общих целях показать, как расширить класс Globalize, здесь мы идем:

Во-первых, убедитесь, что вы включили основной и числовой модули. Тогда ты можешь:

Globalize.parseFloatAcceptDotAndComma =
Globalize.prototype.parseFloatAcceptDotAndComma = function( value, options ) {
    // Assert that value and options are valid.
    // Assert that this.cldr is present

    // I guess you should throw when both . and , are present.
    if ( value.indexOf( "." ) >= 0 && value.indexOf( "," ) >= 0 ) {
        throw new Error("Whops");
    }

    // Important:
    // Note your solution won't handle Arabic and other languages that
    // uses different digits than latin. Therefore, I DO NOT personally
    // recommend it.

    value = value.replace( /[,.]/, this.cldr.main( "numbers/symbols-numberSystem-latn/decimal" ));
    return this.parseNumber( value, options );
};

Вы сможете использовать его как:

Globalize.locale( "en" );
Globalize.parseFloatAcceptDotAndComma( "3,14" );

// Or
var en = new Globalize( "en" );
en.parseFloatAcceptDotAndComma( "3,14" );
Другие вопросы по тегам