Tengo un archivo JSON con datos dentro. Tengo que filtrar los datos por: si el usuario tiene más de dos nombres y si las identificaciones de usuario son consecutivas. El archivo JSON:
[ { "_id": "62bd5fba34a8f1c90303055c", "index": 0, "email": "mcdonaldholden@xerex.com", "nameList": [ { "id": 0, "name": "Wendi Mooney" }, { "id": 2, "name": "Holloway Whitehead" } ] }, { "_id": "62bd5fbac3e5a4fca5e85e81", "index": 1, "nameList": [ { "id": 0, "name": "Janine Barrett" }, { "id": 1, "name": "Odonnell Savage" }, { "id": 2, "name": "Patty Owen" } ] }, ...
Logré encontrar una solución para filtrar si los usuarios tienen más de dos nombres: userData.filter((names,i) => { return names?.nameList?.filter(names => { return names.name;}).length > 2 ; })
Pero parece que no puedo comprender el concepto de filtrar los identificadores consecutivos. También me aconsejaron que no usara ningún bucle for en absoluto. Solo los bucles de matriz ES6 como map, forEach y filter.
Aquí hay una solución que usa every()
para comparar la ID de cada elemento con la ID anterior:
const result = data.filter(({nameList}) => nameList.length > 2 && nameList.every(({id}, i, a) => !i || id === a[i - 1].id + 1) );
Fragmento completo:
const data = [{ "_id": "62bd5fba34a8f1c90303055c", "index": 0, "email": "mcdonaldholden@xerex.com", "nameList": [{ "id": 0, "name": "Wendi Mooney" }, { "id": 2, "name": "Holloway Whitehead" }] }, { "_id": "62bd5fbac3e5a4fca5e85e81", "index": 1, "nameList": [{ "id": 0, "name": "Janine Barrett" }, { "id": 1, "name": "Odonnell Savage" }, { "id": 2, "name": "Patty Owen" }] }]; const result = data.filter(({nameList}) => nameList.length > 2 && nameList.every(({id}, i, a) => !i || id === a[i - 1].id + 1) ); console.log(result);