1. ホーム
  2. javascript

[解決済み] lodashを使ってArrayからオブジェクトを検索して返すには?

2022-04-22 10:58:29

質問

私のオブジェクト

[
    {
        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つです。配列の要素は、以下のような形式のオブジェクトです。 {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]);