var obj = [
{ type: 'number' },
{ type: 'string' },
{
type: 'array',
children: [
{ type: 'number' },
{ type: 'string' }
]
}
]
var convert = function(obj) {
return obj.map(o => ({
'number': 1,
'string': 's',
'array': convert(o.children)
}[o.type]))
}
var convert2 = function(obj) {
return obj.map(o => {
if (o.type === 'number') {
return 1
} else if (o.type === 'string') {
return 's'
} else if (o.type === 'array') {
return convert2(o.children)
} else {
return undefined
}
})
}
var converted = convert(obj)
var converted2 = convert2(obj)
La raison est que chaque attribut d'obj utilisé pour le jugement a été calculé une fois, et un blocage conditionnel peut être ajouté pour l'améliorer :
Lorsqu'il y a peu de conditions à juger, vous pouvez utiliser plusieurs conditions trinoculaires pour juger. S'il y a trop de tels jugements, cette méthode d'écriture devrait être plus belle. Si vous ne pouvez pas l'accepter, vous devrez peut-être écrire autrement.
Parce que votre récursion n'a pas de condition de résiliation
L'erreur est qu'il n'y a pas d'enfants lorsque le premier est signalé