deno.land / std@0.224.0 / collections / filter_keys.ts
12345678910111213141516171819202122232425262728293031323334353637383940414243// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.// This module is browser compatible.
/** * Returns a new record with all entries of the given record except the ones that * have a key that does not match the given predicate. * * @example * ```ts * import { filterKeys } from "https://deno.land/std@$STD_VERSION/collections/filter_keys.ts"; * import { assertEquals } from "https://deno.land/std@$STD_VERSION/assert/assert_equals.ts"; * * const menu = { * "Salad": 11, * "Soup": 8, * "Pasta": 13, * }; * const menuWithoutSalad = filterKeys(menu, (it) => it !== "Salad"); * * assertEquals( * menuWithoutSalad, * { * "Soup": 8, * "Pasta": 13, * }, * ); * ``` */export function filterKeys<T>( record: Readonly<Record<string, T>>, predicate: (key: string) => boolean,): Record<string, T> { const ret: Record<string, T> = {};
for (const [key, value] of Object.entries(record)) { if (predicate(key)) { ret[key] = value; } }
return ret;}
Version Info