lodash를 사용하여 Array에서 객체를 찾아 반환하는 방법은 무엇입니까?


148

내 사물 :

[
    {
        description: 'object1', id: 1
    },
    {
        description: 'object2', id: 2
    }
    {
        description: 'object3', id: 3
    }
    {
        description: 'object4', id: 4
    }
]

아래 함수에서 일치하는 ID를 찾기 위해 설명을 전달합니다.

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의 find 메소드를 사용하려고합니다 : https://lodash.com/docs#find

그러나 내 변수 delete_id가 정의되지 않았습니다.


이 질문을 체크 아웃하는 사람들을 위해 업데이트 한 Ramda는 lodash와 동일한 기능을 수행하지만 더 기능적인 프로그래밍 방식으로 수행하는 훌륭한 라이브러리입니다. : http://ramdajs.com/0.21.0/docs/


1
_.find속성 중 하나만 콜백에 마술처럼 전달할 것이라고 생각하는지 확실하지 않습니다 . console.log(description)콜백에 간단한 내용 이 있습니다.
Felix Kling 2016 년

답변:


176

콜백에 전달 된 인수는 배열의 요소 중 하나입니다. 배열의 요소는 형식의 객체입니다 {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]);

4
감사! 난 그냥 발견이 작품도 var delete_id = _.result(_.find(savedViews, { 'description': view }), 'id');또한 10 개 분 ...
레온 Gaban

두 번째 솔루션이 잘못되었습니다. 술어는 matchesProperty를 사용하는 배열이어야합니다. 속기 :_.find(savedViews, ['description', view])
Franksands

1
@FranciscoGuimaraes : 음, 2015 년으로 돌아가서 lodash가 작동 한 방식 : lodash.com/docs/3.10.1#find
Felix Kling

1
@FelixKling 나는 이것이 이와 같을 것이라고 생각했지만 2018 년에 답을 찾고있는 사람들 (나 같은 사람)에게 의견을 추가하는 것이 더 좋다고 생각했습니다. 답변의 업데이트에 감사드립니다
franksands


29

바닐라 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);

사용 filter(원래 답변)

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.filter(function (el) {
  return el.description === view;
})[0].id;

console.log(delete_id);


6
사실, 그러나 lodash는 훨씬 더 깨끗해 보입니다. 나는 [0]이것을 사용할 필요가 없습니다 var delete_id = _.result(_.find(savedViews, { 'description': view }), 'id');. 데모에 대한 감사 +1
Leon

빈 결과를 강제로 [0] 출력하면 실패하지 않습니까? 따라서 Lodash는 기본적으로 + LeanGaban에 +1을 처리해야합니다.
kiradotee

3
아직도 당신은없이 lodash없이 청소기를 사용할 수 있습니다 @LeonGaban [0] ES6 사용 savedViews.find(el => el.description === view)
램 바부 S

멋진 답변 !!
Ole

11

find메소드를 사용하면 콜백에 다음과 같이 각 요소의 값이 전달됩니다.

{
    description: 'object1', id: 1
}

따라서 다음과 같은 코드를 원합니다.

_.find(savedViews, function(o) {
        return o.description === view;
})

8

이를 위해 _.find의 기본 사용법 예제 인 Array에서 지정된 Object를 찾습니다.

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가 작업에 적합한 도구입니다.


7

Lodash 또는 Ramda 또는 기타 추가 종속성이 필요하지 않습니다.

기능적인 방식으로 ES6 find () 함수를 사용하십시오.

savedViews.find(el => el.description === view)

때때로 당신은 그들과 함께 제공되는 모든 장점을 얻기 위해 타사 라이브러리를 사용해야합니다. 그러나 일반적으로 필요하지 않은 종속성은 피하십시오 . 종속성은 다음과 같습니다.

  • 번들 코드 크기를 늘리고
  • 최신 정보를 유지해야합니다.
  • 버그 나 보안 위험이 발생할 수 있습니다

좋은 대답 !! 정확히 내가 찾던 것.
Ole

6
var delete_id = _(savedViews).where({ description : view }).get('0.id')

6

다음을 사용할 수 있습니다

import { find } from 'lodash'

그런 다음 다음과 같이 목록에서 전체 객체 (키 또는 값뿐만 아니라)를 반환합니다.

let match = find(savedViews, { 'ID': 'id to match'});

4

lodash사용하여 가져 오기

$ npm i-로다시 저장

var _ = require('lodash'); 

var objArrayList = 
    [
         { name: "user1"},
         { name: "user2"}, 
         { name: "user2"}
    ];

var Obj = _.find(objArrayList, { name: "user2" });

// Obj ==> { name: "user2"}

자세한 내용 추가
King Stone

1

이름을 기준으로 ID 가져 오기

 {
    "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;
        },
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.