aboutsummaryrefslogtreecommitdiff
path: root/files/pt-br/web/javascript/reference/classes/constructor/index.html
diff options
context:
space:
mode:
Diffstat (limited to 'files/pt-br/web/javascript/reference/classes/constructor/index.html')
-rw-r--r--files/pt-br/web/javascript/reference/classes/constructor/index.html174
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>