diff options
Diffstat (limited to 'files/pt-br/web/javascript/reference/classes/constructor')
-rw-r--r-- | files/pt-br/web/javascript/reference/classes/constructor/index.html | 174 |
1 files changed, 174 insertions, 0 deletions
diff --git a/files/pt-br/web/javascript/reference/classes/constructor/index.html b/files/pt-br/web/javascript/reference/classes/constructor/index.html new file mode 100644 index 0000000000..3b8a64429b --- /dev/null +++ b/files/pt-br/web/javascript/reference/classes/constructor/index.html @@ -0,0 +1,174 @@ +--- +title: constructor +slug: Web/JavaScript/Reference/Classes/constructor +tags: + - Classes + - ECMAScript6 + - Experimental + - JavaScript orientado a objetos + - Nova versão JavaScript +translation_of: Web/JavaScript/Reference/Classes/constructor +--- +<div>O construtor é um método especial para criar e inicializar um objeto criado a partir de uma classe.</div> + +<div></div> + +<div></div> + +<h2 id="Sintaxe">Sintaxe</h2> + +<pre class="syntaxbox notranslate">constructor([argumentos]) { ... }</pre> + +<h2 id="Descrição">Descrição</h2> + +<p>Apenas um método especial com o nome <em>constructor</em> pode existir em uma classe. O erro {{jsxref("SyntaxError")}} será mostrado se a classe contiver mais de um método <em>constructor.</em></p> + +<p>Um construtor pode usar a palavra reservada <em>super</em> para se referir ao construtor da classe pai (<strong>superior</strong>).</p> + +<p>Um construtor padrão será usado se você não especificá-lo<em>.</em></p> + +<h2 id="Exemplos">Exemplos</h2> + +<h3 id="Usando_o_método_constructor">Usando o método <em>constructor</em></h3> + +<p>O trecho de código foi fornecido por <a href="https://github.com/GoogleChrome/samples/blob/gh-pages/classes-es6/index.html">exemplo de classes</a> (<a href="https://googlechrome.github.io/samples/classes-es6/index.html">live demo</a>).</p> + +<pre class="brush: js notranslate">class Quadrado extends Poligono { + constructor(comprimento) { + // super chama o construtor da classe pai que vai atribuir comprimento para + // os atributos comprimento e altura herdados pela nossa classe filha Quadrado + super(comprimento, comprimento); + // Nas classes filhas, <em>super()</em> deve ser chamado antes de usar o <em>this</em>. Sem ele + // vai ocorrer um erro de referência. O <em>this</em> agora se refere a classe filha Quadrado + this.nome = 'Quadrado'; + } + + // os atributos a seguir são herdados da classe pai Poligono: altura, comprimento e area. + + get area() { + return this.altura * this.comprimento; + } + + set area(valor) { + this.area = valor; + } +}</pre> + +<h3 id="Construtores_padrão_constructors">Construtores padrão (<em>constructors</em>)</h3> + +<p>Um construtor padrão será usado pela classe caso nenhum seja especificado. Para as classes de base o construtor padrão é:</p> + +<pre class="brush: js notranslate">constructor() {} //construtor criado por padrão +</pre> + +<p>Para as classes filhas o construtor padrão é:</p> + +<pre class="brush: js notranslate">constructor(...args) { + super(...args); +}</pre> + +<h2 id="Especificações">Especificações</h2> + +<table class="standard-table"> + <tbody> + <tr> + <th scope="col">Especificação</th> + <th scope="col">Status</th> + <th scope="col">Comentário</th> + </tr> + <tr> + <td>{{SpecName('ES6', '#sec-static-semantics-constructormethod', 'Constructor Method')}}</td> + <td>{{Spec2('ES6')}}</td> + <td>Definição inicial</td> + </tr> + <tr> + <td>{{SpecName('ESDraft', '#sec-static-semantics-constructormethod', 'Constructor Method')}}</td> + <td>{{Spec2('ESDraft')}}</td> + <td></td> + </tr> + </tbody> +</table> + +<h2 id="Compatibilidade_de_navegadores">Compatibilidade de navegadores</h2> + +<p><br> + Download da versão Firefox para testes (Nightly) em: https://nightly.mozilla.org/</p> + +<div id="compat-desktop"> +<table class="compat-table"> + <tbody> + <tr> + <th>Característica</th> + <th>Chrome</th> + <th>Firefox (Gecko)</th> + <th>Internet Explorer</th> + <th>Opera</th> + <th>Safari</th> + </tr> + <tr> + <td>Suporte básico</td> + <td>Chrome(42.0)</td> + <td>Nightly</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + </tr> + <tr> + <td>Construtores padrão</td> + <td>Desconhecido</td> + <td>Nightly</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + </tr> + </tbody> +</table> +</div> + +<div id="compat-mobile"> +<table class="compat-table"> + <tbody> + <tr> + <th>Característica</th> + <th>Android</th> + <th>Android Webview</th> + <th>Firefox Mobile (Gecko)</th> + <th>IE Mobile</th> + <th>Opera Mobile</th> + <th>Safari Mobile</th> + <th>Chrome for Android</th> + </tr> + <tr> + <td>Suporte básico</td> + <td>Não</td> + <td>Chrome(42.0)</td> + <td>CompatNightly</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>CompatChrome(42.0)</td> + </tr> + <tr> + <td>Construtores padrão</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>CompatNightly</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>Desconhecido</td> + <td>Desconhecido}}</td> + </tr> + </tbody> +</table> +</div> + +<h2 id="sect1"></h2> + +<h2 id="Veja_também">Veja também</h2> + +<ul> + <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/super">super()</a></li> + <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/class"><code>class</code> expressão</a></li> + <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/class"><code>class</code> declaração</a></li> + <li><a href="/en-US/docs/Web/JavaScript/Reference/Classes">Classes</a></li> +</ul> |