Как использовать lodash для поиска и возврата объекта из массива?
Мои объекты:
[
{
description: 'object1', id: 1
},
{
description: 'object2', id: 2
}
{
description: 'object3', id: 3
}
{
description: 'object4', id: 4
}
]
В моей функции ниже я передаю описание, чтобы найти соответствующий идентификатор:
function pluckSavedView(action, view) {
console.log('action: ', action);
console.log('pluckSavedView: ', view); // view = 'object1'
var savedViews = retrieveSavedViews();
console.log('savedViews: ', savedViews);
if (action === 'delete') {
var delete_id = _.result(_.find(savedViews, function(description) {
return description === view;
}), 'id');
console.log('delete_id: ', delete_id); // should be '1', but is undefined
}
}
Я пытаюсь использовать метод поиска lodash: https://lodash.com/docs#find
Однако моя переменная delete_id
выходит неопределенной.
Обновление для людей, проверяющих этот вопрос. Ramda - хорошая библиотека, которая делает то же самое, что делает lodash, но более функциональным способом программирования :) http://ramdajs.com/0.21.0/docs/
Ответы
Ответ 1
Аргумент, переданный обратному вызову, является одним из элементов массива. Элементами вашего массива являются объекты вида {description:..., id:...}
.
var delete_id = _.result(_.find(savedViews, function(obj) {
return obj.description === view;
}), 'id');
Еще одна альтернатива из документов, с которыми вы связаны (lodash v3):
_.find(savedViews, 'description', view);
Lodash v4:
_.find(savedViews, ['description', view]);
Ответ 2
lodash и ES5
var song = _.find(songs, {id:id});
lodash и ES6
let song = _.find(songs, {id});
docs на https://lodash.com/docs#find
Ответ 3
Вы можете сделать это легко в ванильном JS:
Использование find
const savedViews = [{"description":"object1","id":1},{"description":"object2","id":2},{"description":"object3","id":3},{"description":"object4","id":4}];
const view = 'object2';
const delete_id = savedViews.find(obj => {
return obj.description === view;
}).id;
console.log(delete_id);
Ответ 4
С помощью метода find
ваш обратный вызов будет передан значение каждого элемента, например:
{
description: 'object1', id: 1
}
Таким образом, вам нужен код типа:
_.find(savedViews, function(o) {
return o.description === view;
})
Ответ 5
var delete_id = _(savedViews).where({ description : view }).get('0.id')
Ответ 6
Вам не нужны Лодаш, Рамда или любая другая дополнительная зависимость.
Просто используйте функцию ES6 find() функционально:
savedViews.find(el => el.description === view)
Иногда вам нужно использовать сторонние библиотеки, чтобы получить все вкусности, которые идут с ними. Однако, вообще говоря, старайтесь избегать зависимостей, когда они вам не нужны. Зависимости могут:
- раздувать ваш размер кода в комплекте,
- Вы должны будете держать их в курсе,
- и они могут представлять ошибки или угрозы безопасности
Ответ 7
для этого найдите данный объект в массиве, базовом примере использования _.find
const array =
[
{
description: 'object1', id: 1
},
{
description: 'object2', id: 2
},
{
description: 'object3', id: 3
},
{
description: 'object4', id: 4
}
];
это будет хорошо работать
q = _.find(array, {id:'4'}); // delete id
console.log(q); // {description: 'object4', id: 4}
_.find поможет вернуть элемент в массиве, а не его индекс. Так что, если у вас есть массив объектов, и вы хотите найти отдельный объект в массиве по определенному значению ключа, pare _.find - подходящий инструмент для работы.
Ответ 8
Вы можете использовать следующее
import { find } from 'lodash'
Затем вернуть весь объект (не только его ключ или значение) из списка со следующим:
let match = find(savedViews, { 'ID': 'id to match'});
Ответ 9
Импортируйте lodash
используя
$ npm i --save lodash
var _ = require('lodash');
var objArrayList =
[
{ name: "user1"},
{ name: "user2"},
{ name: "user2"}
];
var Obj = _.find(objArrayList, { name: "user2" });
// Obj ==> { name: "user2"}
Ответ 10
let labArray = [{id: 1, name: 'user1'}, {id: 2, name: 'user1'}, {id: 3, name: 'user1'}]; let selectedLabId = 2; let selectedLabInfo = _.find(labArray, {'id': parseInt (selectedLabId)});
Ответ 11
Получить идентификатор на основе имени
{
"roles": [
{
"id": 1,
"name": "admin",
},
{
"id": 3,
"name": "manager",
}
]
}
fetchIdBasingOnRole() {
const self = this;
if (this.employee.roles) {
var roleid = _.result(
_.find(this.getRoles, function(obj) {
return obj.name === self.employee.roles;
}),
"id"
);
}
return roleid;
},