PreParsePostFormat
O Pre-parse / Post-format permite que você processe a entrada antes da análise (parsing) e processe a saída da string após a formatação. Baseado em um comportamento similar para localidades no moment.js.
NOTA: Este plugin requer que o plugin localeData
seja importado antes de sua utilização, pois depende de sua funcionalidade.
NOTA: Este plugin também afeta o plugin de tempo relativo, replicando o comportamento de implementação do moment.js.
Exemplo de uso
Por exemplo, no locale AR (árabe) especificamente, ele é usado para suportar numerais arábicos.
// Árabe [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, '،');
},
// ...
};
// ...
Os testes também podem fornecer uma boa compreensão de como usar o plugin, caso isso não esteja claro o suficiente 😉.