This page was translated from English by the community.Learn more and join the MDN Web Docs community.
handler.set()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since сентябрь 2016 г..
Методhandler.set() является ловушкой для установки значения свойству.
In this article
Синтаксис
var p = new Proxy(target, { set: function (target, property, value, receiver) {},});Параметры
Следующие параметры передаются методуset() .this привязан к обработчику
targetИсходный объект, который проксируется.
propertyИмя свойства, в которое устанавливается значение
value.valueЗначение, устанавливаемое в свойство
property.receiverОбъект, которому первоначально было присвоено задание. Обычно это сам прокси. Но обработчик
set()также может быть вызван косвенно, через цепочку прототипов или различными другими способами.Например, предположим, что скрипт выполняетobj.name = "jen", при этомobjне является прокси и не имеет собственного свойства.name, но имеет прокси в цепочке прототипов. Будет вызван обработчик проксиset(), аobjбудет передан в качестве получателя.
Возвращаемые результаты
Методset должен возвращать boolean значение.
- Возвращает
true, если присвоение выполнено успешно. - Если метод
set()возвращаетfalse, а присваивание произошло в коде строгого режима, то будет выброшенаTypeError.
Описание
Методhandler.set является ловушкой для установки значения свойству.
Перехват
Эта ловушка может перехватывать следующие операции:
- Установка значения свойству:
proxy[foo] = barandproxy.foo = bar - Установка значения наследованному свойству:
Object.create(proxy)[foo] = bar Reflect.set()
Инварианты
Если нарушены следующие инварианты, то proxy выброситTypeError:
- Невозможно изменить значение свойства так, чтобы оно отличалось от значения соответствующего свойства целевого объекта, если соответствующее свойство целевого объекта не является доступным для записи и не настраиваемым свойством данных.
- Невозможно установить значение свойства, если соответствующее свойство целевого объекта является неконфигурируемым свойством средства доступа, для которого в качестве атрибута [[Set]] указано значение undefined.
- В строгом режиме при возврате из обработчика
set()значенияfalse, будет выброшено исключениеTypeError.
Примеры
Следующий код перехватывает установку значения свойству.
var p = new Proxy( {}, { set: function (target, prop, value, receiver) { target[prop] = value; console.log("property set: " + prop + " = " + value); return true; }, },);console.log("a" in p); // falsep.a = 10; // "property set: a = 10"console.log("a" in p); // trueconsole.log(p.a); // 10Спецификации
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-proxy-object-internal-methods-and-internal-slots-set-p-v-receiver> |