PreParsePostFormat
預先解析/後置格式化讓您在解析器之前處理輸入,並在格式化器之後處理字串輸出。 基於 moment.js 中地區設定的類似行為。
注意:此外掛程式需要先匯入 localeData 外掛程式(因為它依賴其功能)。
注意:此外掛程式也會影響相對時間外掛程式,這也是設計使然(模仿 moment.js 實作行為)。
範例用法
// 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, '،')
},
// ...
}
// ...
測試也應該可以讓您清楚了解如何使用外掛程式,如果還不夠清楚的話 ;)。