PreParsePostFormat
預解析與後格式化 允許你在解析器處理輸入之前,以及格式化器處理字串輸出之後,對輸入和輸出進行處理。基於 moment.js 中本地化功能的類似實現。
注意: 此插件需要在 localeData
插件之前導入,因為它依賴於後者。
注意: 此插件也會影響相對時間插件,這是設計上的考量,與 moment.js 的實現保持一致。
示例用法
javascript
// 阿拉伯語 [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, '،');
},
// ...
};
// ...
如果以上範例不夠清晰,這些測試案例可以協助你更深入了解如何使用此插件。