PreParsePostFormat
Pre-parse / Post-format は、パーサーが入力文字列を処理する前、およびフォーマッターが出力文字列を生成した後に、それぞれ処理を追加することを可能にします。moment.js のロケールにおける同様の機能に基づいています。
注意: このプラグインは、localeData プラグインの機能に依存するため、事前に localeData プラグインをインポートする必要があります。
注意: このプラグインは、設計上 relative time プラグインにも影響を与えます (moment.js の実装を模倣しています)。
使用例
例として: 特に AR ロケールでは、アラビア数字をサポートするために使用されています。
javascript
// 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, '،');
},
// ...
};
// ...
テストケースも、このプラグインの使用方法を理解する上で役立つでしょう。