--- title: Reflect.set() slug: Web/JavaScript/Reference/Global_Objects/Reflect/set tags: - ECMAScript 2015 - JavaScript - Method - Reference - Reflect translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/set ---
{{JSRef}}

静的な Reflect.set() メソッドは、オブジェクトにプロパティを設定するかのように動作します。

{{EmbedInteractiveExample("pages/js/reflect-set.html")}}

構文

Reflect.set(target, propertyKey, value[, receiver])

引数

target
プロパティを設定する対象のオブジェクト。
propertyKey
設定するプロパティ名。
value
設定する値。
receiver {{optional_inline}}
セッターによって target が呼び出されたときの this 値を提供する。

返値

プロパティが成功裏に設定できたかどうかを示す {{jsxref("Boolean")}} 値。

例外

{{jsxref("TypeError")}}: target が {{jsxref("Object")}} ではなかった場合。

解説

Reflect.set メソッドは、オブジェクトにプロパティを設定します。これはプロパティの割り当てを行い、機能としては プロパティアクセサー 構文のようなものです。

Reflect.set() の使用

// オブジェクト
let obj = {}
Reflect.set(obj, 'prop', 'value')  // true
obj.prop  // "value"

// 配列
let arr = ['duck', 'duck', 'duck']
Reflect.set(arr, 2, 'goose')  // true
arr[2]  // "goose"

// 配列を切り詰められる。
Reflect.set(arr, 'length', 1)  // true
arr  // ["duck"]

// 引数が1つだけだと、プロパティキーと値は "undefined" になる。
let obj = {}
Reflect.set(obj)  // true
Reflect.getOwnPropertyDescriptor(obj, 'undefined')
// { value: undefined, writable: true, enumerable: true, configurable: true }

仕様書

仕様書
{{SpecName('ESDraft', '#sec-reflect.set', 'Reflect.set')}}

ブラウザーの互換性

{{Compat("javascript.builtins.Reflect.set")}}

関連情報