[譯]JS Tips:選擇(picking)和反選(rejecting)對象的屬性

這是我在 JS Tips 上翻譯的一篇文章, 原文在官網:選擇(picking)和反選(rejecting)對象的屬性javascript

有時候咱們須要將一個對象的某些屬性放到白名單裏,這樣來講,咱們有一個數組表明了一張數據庫表,而且爲了一些功能咱們須要從中選出(select)一些字段:java

function pick(obj, keys) {
    return keys.map(k => k in obj ? {[k]: obj[k]} : {})
               .reduce((res, o) => Object.assign(res, o), {});
}

const row = {
    'accounts.id': 1,
    'client.name': 'John Doe',
    'bank.code': 'MDAKW213'
};

const table = [
    row,
    {'accounts.id': 3, 'client.name': 'Steve Doe', 'bank.code': 'STV12JB'}
];

pick(row, ['client.name']); // 取到了 client name

table.map(row => pick(row, ['client.name'])); // 取到了一系列 client name複製代碼

在 pick 函數中用到了一點‘詭計’。首先,咱們用 map 遍歷了鍵名數組(keys), 每次都會返回一個包含當前鍵名(key)的對象(若是在目標對象(obj)中沒有當前鍵名,就會返回空對象)。而後咱們用 reduce 把返回的全部單個鍵-值對象和合併到一個對象中。數據庫

可是,若是咱們想反選(reject)屬性/鍵名呢?改造一下咱們的函數就行了:數組

function reject(obj, keys) {
    return Object.keys(obj)
        .filter(k => !keys.includes(k))
        .map(k => ({[k]: obj[k]}))
        .reduce((res, o) => Object.assign(res, o), {});
}

// 或者, 利用 pick
function reject(obj, keys) {
    const vkeys = Object.keys(obj)
        .filter(k => !keys.includes(k));
    return pick(obj, vkeys);
}

reject({a: 2, b: 3, c: 4}, ['a', 'b']); // => {c: 4}複製代碼
相關文章
相關標籤/搜索