PreParsePostFormat
Pre-parse / Post-format umożliwia przetwarzanie danych wejściowych przed parsowaniem oraz przetwarzanie ciągu wyjściowego po formatowaniu. Oparte na podobnym mechanizmie dla ustawień regionalnych w moment.js.
UWAGA: Ta wtyczka wymaga zaimportowania wtyczki localeData
przed jej użyciem (ponieważ zależy od jej funkcjonalności).
UWAGA: Ta wtyczka wpływa również na działanie wtyczki relativeTime
, zgodnie z założeniami (naśladuje zachowanie implementacji moment.js).
Przykładowe użycie
Na przykład, [w ustawieniach regionalnych AR jest stosowana do obsługi cyfr arabskich].
// Arabic [ar]
import dayjs from 'dayjs';
import preParsePostFormat from 'dayjs/plugin/preParsePostFormat';
dayjs.extend(preParsePostFormat);
const months =
'يناير_فبراير_مارس_أبريل_مايو_يونيو_يوليو_أغسطس_سبتمبر_أكتوبر_نوفمبر_ديسمبر'.split(
'_'
);
const symbolMap = {
1: '١',
2: '٢',
3: '٣',
4: '٤',
5: '٥',
6: '٦',
7: '٧',
8: '٨',
9: '٩',
0: '٠',
};
const numberMap = {
'١': '1',
'٢': '2',
'٣': '3',
'٤': '4',
'٥': '5',
'٦': '6',
'٧': '7',
'٨': '8',
'٩': '9',
'٠': '0',
};
const locale = {
name: 'ar',
// ...
preparse(string) {
return string
.replace(/[١٢٣٤٥٦٧٨٩٠]/g, match => numberMap[match])
.replace(/،/g, ',');
},
postformat(string) {
return string.replace(/\d/g, match => symbolMap[match]).replace(/,/g, '،');
},
// ...
};
// ...
Testy powinny również dać dobry obraz tego, jak używać wtyczki, jeśli powyższe informacje są niewystarczające 😃.