/** Used to stand-in for `undefined` hash values. */ /** 用于代替“未定义的”散列值。 */ const HASH_UNDEFINED = '__lodash_hash_undefined__'; class Hash { /** * Creates a hash object. * 创建一个散列对象。 * @private * @constructor * @param {Array} [entries] 要缓存的键值对. */ constructor(entries) { let index = -1; const length = entries == null ? 0 : entries.length; this.clear(); while (++index < length) { const entry = entries[index]; this.set(entry[0], entry[1]); } } /** * Removes all key-value entries from the hash. * 从散列中删除所有键值项。 * @memberOf Hash */ clear() { this.__data__ = Object.create(null); this.size = 0; } /** * Removes `key` and its value from the hash. * 从散列中删除' key '及其值。 * @memberOf Hash * @param {Object} hash 要修改的散列。 * @param {string} key 要删除的值的键。 * @returns {boolean} 如果条目被删除,则返回“true”,否则返回“false” */ delete(key) { const result = this.has(key) && delete this.__data__[key]; this.size -= result ? 1 : 0; return result; } /** * Gets the hash value for `key`. * 获取' key '的散列值。 * @memberOf Hash * @param {string} key 要获取的值的键。 * @returns {*} 返回条目值。 */ get(key) { const data = this.__data__; const result = data[key]; return result === HASH_UNDEFINED ? undefined : result; } /** * Checks if a hash value for `key` exists. * 检查' key '的哈希值是否存在。 * @memberOf Hash * @param {string} key 输入键值检查。 * @returns {boolean} 如果' key '的条目存在,则返回' true ',否则返回' false '。 */ has(key) { const data = this.__data__; return data[key] !== undefined; } /** * Sets the hash `key` to `value`. * 将散列“key”设置为“value”。 * @memberOf Hash * @param {string} key 要设置的值的键. * @param {*} value 要设置的值。 * @returns {Object} 返回哈希实例。 */ set(key, value) { const data = this.__data__; this.size += this.has(key) ? 0 : 1; data[key] = value === undefined ? HASH_UNDEFINED : value; return this; } } export default Hash;