您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“JavaScript中選取picking和反選rejecting對象的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“JavaScript中選取picking和反選rejecting對象的示例分析”這篇文章吧。
有時候我們需要將一個對象的某些屬性選取出來,比方說我們有一個用數組表示的數據庫表,我們需要一些函數來 select (選取) 幾個字段:
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}
以上是“JavaScript中選取picking和反選rejecting對象的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。