1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
---
title: Reflect.defineProperty()
slug: Web/JavaScript/Reference/Global_Objects/Reflect/defineProperty
tags:
- ECMAScript 2015
- JavaScript
- Referencia
- Reflect
- metodo
translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/defineProperty
---
<div>{{JSRef}}</div>
<p>O método estático <code><strong>Reflect</strong></code><strong><code>.defineProperty()</code></strong> é como o {{jsxref("Object.defineProperty()")}}, mas retorna um {{jsxref("Boolean")}}.</p>
<div>{{EmbedInteractiveExample("pages/js/reflect-defineproperty.html")}}</div>
<h2 id="Sintaxe">Sintaxe</h2>
<pre class="syntaxbox notranslate">Reflect.defineProperty(<var>target</var>, <var>propertyKey</var>, <var>attributes</var>)
</pre>
<h3 id="Parâmetros">Parâmetros</h3>
<dl>
<dt><code><var>target</var></code></dt>
<dd>O objeto de destino onde será definida a propriedade.</dd>
<dt><code><var>propertyKey</var></code></dt>
<dd>O nome da propriedade a ser definida ou modificada.</dd>
<dt><code><var>attributes</var></code></dt>
<dd>Os atributos para a propriedade que está sendo definida ou modificada.</dd>
</dl>
<h3 id="Valor_de_retorno">Valor de retorno</h3>
<p>Um {{jsxref("Boolean")}} indicando se a propriedade foi ou não definida com êxito.</p>
<h3 id="Erros">Erros</h3>
<p>Um {{jsxref("TypeError")}}, se <code><var>target</var></code> não for um {{jsxref("Object")}}.</p>
<h2 id="Descrição">Descrição</h2>
<p>O método <code>Reflect.defineProperty</code> permite a adição precisa ou a modificação de uma propriedade em um objeto. Para mais detalhes veja o {{jsxref("Object.defineProperty")}}, que é semelhante.</p>
<div class="blockIndicator note">
<p><strong>Uma diferença fundamental:</strong> <code>Object.defineProperty</code> retorna o objeto ou lança um {{jsxref ("TypeError")}} se a propriedade não tiver sido definida com êxito. <code>Reflect.defineProperty</code>, no entanto, simplesmente retorna um {{jsxref ("Boolean")}} indicando se a propriedade foi ou não definida com êxito.</p>
</div>
<h2 id="Exemplos">Exemplos</h2>
<h3 id="Usando_Reflect.defineProperty">Usando <code>Reflect.defineProperty()</code></h3>
<pre class="brush: js notranslate">let obj = {}
Reflect.defineProperty(obj, 'x', {value: 7}) // true
obj.x // 7
</pre>
<h3 id="Verificando_se_a_definição_da_propriedade_foi_bem-sucedida">Verificando se a definição da propriedade foi bem-sucedida</h3>
<p>Com o {{jsxref ("Object.defineProperty")}}, que retorna um objeto se for bem-sucedido ou lança um {{jsxref ("TypeError")}}, você usaria um bloco <a href="/en-US/docs/Web/JavaScript/Reference/Statements/try...catch">try...catch</a> para detectar qualquer erro que ocorreu ao definir uma propriedade.</p>
<p>Como <code>Reflect.defineProperty</code> retorna um status de sucesso booleano, você pode usar apenas um bloco <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/if...else">if...else</a></code> aqui:</p>
<pre class="brush: js notranslate">if (Reflect.defineProperty(target, property, attributes)) {
// success
} else {
// failure
}</pre>
<h2 id="Especificações">Especificações</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Especificação</th>
</tr>
<tr>
<td>{{SpecName('ESDraft', '#sec-reflect.defineproperty', 'Reflect.defineProperty')}}</td>
</tr>
</tbody>
</table>
<h2 id="Browser_compatibility">Compatibilidade com navegadores</h2>
<p>{{Compat("javascript.builtins.Reflect.defineProperty")}}</p>
<h2 id="Veja_também">Veja também</h2>
<ul>
<li>{{jsxref("Reflect")}}</li>
<li>{{jsxref("Object.defineProperty()")}}</li>
</ul>
|