【发布时间】:2019-07-04 07:14:02
【问题描述】:
我有一个函数接收两个参数,我希望它们是可选的(最后两个):
const renderDate = (date, locale, format) => {
if (locale === undefined) { locale = 'en' }
if (format === undefined) { format = 'D MMM' }
if (locale === 'de' && format === 'D MMM') {
const indexD = format.lastIndexOf('D')
format = `${format.slice(0, indexD + 1)}o${format.slice(indexD + 1, format.length)}`
}
moment.locale(locale)
return moment(date).format(format)
}
console.log(renderDate('2019-09-04', 'Do MMM'));
<script src="https://momentjs.com/downloads/moment.js"></script>
我不能这样做:
const renderDate = (date, locale = 'en', format = 'D MMM') => {
if (locale === 'de' && format === 'D MMM') {
const indexD = format.lastIndexOf('D')
format = `${format.slice(0, indexD + 1)}o${format.slice(indexD + 1, format.length)}`
}
moment.locale(locale)
return moment(date).format(format)
}
因为如果我只使用 1 个可选参数调用该方法,则可能是错误的:
renderDate('2019-09-04', 'Do MMM')
现在 locale(语言)是一种格式,这是错误的。
解决此问题的最佳方法是什么? 我应该传递一个对象然后检查键是否存在?
然后我可以解构,但我不确定这是否是最好的方法:
const renderDate = ({
date,
locale,
format
}) => {
if (locale === undefined) {
locale = 'en'
}
if (format === undefined) {
format = 'D MMM'
}
if (locale === 'de' && format === 'D MMM') {
const indexD = format.lastIndexOf('D')
format = `${format.slice(0, indexD + 1)}o${format.slice(indexD + 1, format.length)}`
}
moment.locale(locale)
return moment(date).format(format)
}
console.log(renderDate('2019-09-04', 'Do MMM'));
<script src="https://momentjs.com/downloads/moment.js"></script>
【问题讨论】:
标签: javascript function ecmascript-6 momentjs