Алгоритм поиска
важность: 5
Задача состоит из двух частей.
У нас есть объекты:
let head = {
glasses: 1
};
let table = {
pen: 3
};
let bed = {
sheet: 1,
pillow: 2
};
let pockets = {
money: 2000
};
- С помощью свойства
__proto__задайте прототипы так, чтобы поиск любого свойства выполнялся по следующему пути:pockets→bed→table→head. Например,pockets.penдолжно возвращать значение3(найденное вtable), аbed.glasses– значение1(найденное вhead). - Ответьте на вопрос: как быстрее получить значение
glasses– черезpockets.glassesили черезhead.glasses? При необходимости составьте цепочки поиска и сравните их.
-
Добавим свойство
__proto__:let head = { glasses: 1 }; let table = { pen: 3, __proto__: head }; let bed = { sheet: 1, pillow: 2, __proto__: table }; let pockets = { money: 2000, __proto__: bed }; alert( pockets.pen ); // 3 alert( bed.glasses ); // 1 alert( table.money ); // undefined -
С точки зрения производительности, для современных движков неважно, откуда берётся свойство – из объекта или из прототипа. Они запоминают, где было найдено свойство, и повторно используют его в следующем запросе.
Например, при обращении к
pockets.glassesони запомнят, что нашлиglassesвhead, и в следующий раз будут искать там же. Они достаточно умны, чтобы при изменениях обновлять внутренний кеш, поэтому такая оптимизация безопасна.