diff options
Diffstat (limited to 'files/pt-br/web/javascript/reference/statements/var/index.html')
-rw-r--r-- | files/pt-br/web/javascript/reference/statements/var/index.html | 238 |
1 files changed, 238 insertions, 0 deletions
diff --git a/files/pt-br/web/javascript/reference/statements/var/index.html b/files/pt-br/web/javascript/reference/statements/var/index.html new file mode 100644 index 0000000000..6f3ec18977 --- /dev/null +++ b/files/pt-br/web/javascript/reference/statements/var/index.html @@ -0,0 +1,238 @@ +--- +title: var +slug: Web/JavaScript/Reference/Statements/var +tags: + - JavaScript +translation_of: Web/JavaScript/Reference/Statements/var +--- +<div> +<div>{{jsSidebar("Statements")}}</div> +</div> + +<h2 id="Sumário">Sumário</h2> + +<p>O <strong><code>variable</code> statement</strong> declara uma variável, opcionalmente é possível atribuir à ela um valor em sua inicialização.</p> + +<h2 id="Syntax" name="Syntax">Sintaxe</h2> + +<pre class="syntaxbox">var <em>varname1 [</em>= <em>value1 [</em>, <em>varname2 [</em>, <em>varname3 ... [</em>, <em>varnameN]]]]</em>;</pre> + +<dl> + <dt><code>varnameN</code></dt> + <dd>Nome da variável. Pode ser utilizado qualquer identificador legal.</dd> +</dl> + +<dl> + <dt><code>valueN</code></dt> + <dd>Valor inicial da variável. Pode ser qualquer expressão legal.</dd> +</dl> + +<h2 id="Description" name="Description">Descrição</h2> + +<p>Declarações de variáveis, onde quer que elas ocorram, são processadas antes que qualquer outro código seja executado. O escopo de uma variável declarada com <code>var</code> é seu contexto atual em execução, o qual é a função a qual pertence ou, para variáveis declaradas fora de qualquer função, o escopo é o global.</p> + +<p>Atribuir um valor a uma variável não declarada anteriormente implica em criar uma variável global (ela se torna uma propriedade do objeto global) quando a atribuição é executada. As diferenças entre uma variável declarada e uma não delcarada são:</p> + +<p>1. Variáveis declaradas estão relacionadas com o contexto de execução quando elas são criadas (por exemplo, uma função, objeto). Por outro lado, as variaveis não declaradas sempre são globais.</p> + +<pre class="brush: js">function x() { + y = 1; // Lança a exceção ReferenceError em modo restrito (strict mode) + var z = 2; +} + +x(); + +console.log(y); // logs "1" +console.log(z); // Lança a exceção ReferenceError: z não foi definida fora da função x() +</pre> + +<p>2. Variáveis declaradas são criadas antes de qualquer código ser executado. As variáveis não declaradas não existem até quando o código atribuir um valor a ela.</p> + +<pre class="brush: js">console.log(a); // Lança a exceção ReferenceError. +console.log('still going...'); // Nunca será executado.</pre> + +<pre class="brush: js">var a; +console.log(a); // mostra "undefined" ou "" dependendo do naveador. +console.log('still going...'); // mostra "still going...".</pre> + +<p>3. Variáveis declaradas são propriedades não configuráveis no contexto de execução (função ou global). Variaveis não declaradas são configuráveis (por exemplo, podem ser excluídas).</p> + +<pre class="brush: js">var a = 1; +b = 2; + +delete this.a; // Lança a exceção TypeError em modo restrito(strict mode). Caso contrário, Falha silenciosamente. +delete this.b; + +console.log(a, b); // Throws a ReferenceError. +// A propriedade 'b' foi deletada e não existe mais.</pre> + +<p>Por conta dessas três diferenças, falha para declarar variáveis, muito provavelmente, levar a resultados inesperados. <strong>Então, é recomendado sempre declarar as variáveis, independentemente se as variáveis estão em escopo de função ou escopo global</strong>. E o modo restrito (<a href="/en-US/docs/Web/JavaScript/Reference/Functions_and_function_scope/Strict_mode">strict mode</a>) do ECMAScript 5 sempre lançará uma exceçao quando o código atribuir um valor a uma variável não declarada.</p> + +<h3 id="var_hoisting">var hoisting</h3> + +<p>Como as declarações de variáveis (e declarações em geral) são processadas antes de qualquer código seja executado, declarar uma variável em qualquer lugar no código é equivalente a declarar no inicio. Isso também significa que uma variável pode aparecer para ser usada antes dela ser declarada. Esse comportamento é chamado de "hoisting", a variável é movida para o inicio da função ou do código global.</p> + +<pre class="brush: js">bla = 2 +var bla; +// ... + +// é implicitamente entendido como: + +var bla; +bla = 2; +</pre> + +<p>Por essa razão, recomenda-se sempre declarar variáveis na parte superior do seu escopo de aplicação (o topo do código global e a parte superior do código da função). Por isso, é claro que as variáveis são função de escopo (local) e que são resolvidos na cadeia de escopo.</p> + +<h2 id="Examples" name="Examples">Exemplos</h2> + +<h3 id="Declarando_e_inicializando_duas_variáveis">Declarando e inicializando duas variáveis</h3> + +<pre class="brush: js">var a = 0, b = 0; +</pre> + +<h3 id="Atribuindo_duas_variáveis_com_uma_única_expressão">Atribuindo duas variáveis com uma única expressão</h3> + +<pre class="brush: js">var a = "A"; +var b = a; + +// Equivalente a: + +var a, b = a = "A"; +</pre> + +<p>É sempre importante lembrar da ordem da declaração das variáveis:</p> + +<pre class="brush: js">var x = y, y = 'A'; +console.log(x + y); // undefinedA +</pre> + +<p>Então, <span style="font-family: consolas,monaco,andale mono,monospace;">x</span> e <span style="font-family: consolas,monaco,andale mono,monospace;">y</span> são declarados antes de qualquer código seja executado, a atribuição ocorre posteriormente. Quando "<span style="font-family: consolas,monaco,andale mono,monospace;">x = y</span>" for executado, y existe e nenhum exceção <span style="font-family: consolas,monaco,andale mono,monospace;">ReferenceError</span> é lançada, e o valor de y será considerado como '<code style="font-style: normal;">undefined</code>'. Por este motivo, este valor é atribuido a <span style="font-family: consolas,monaco,andale mono,monospace;">x</span>. Depois disso, o valor 'A' é atribuido a variável <span style="font-family: consolas,monaco,andale mono,monospace;">y</span>. Consequentemente, depois da primeira linha, <span style="font-family: consolas,monaco,andale mono,monospace;">x === undefined && y === 'A'</span>, então o resultado.</p> + +<h3 id="Iniciando_diversas_variáveis">Iniciando diversas variáveis</h3> + +<pre class="brush: js">var x = 0; + +function f(){ + var x = y = 1; // x é declarado localmente,y não é! +} +f(); + +console.log(x, y); // 0, 1 +// x é uma variável global como experado +// y vazou para fora da função!</pre> + +<h3 id="Variável_global_implícita_e_fora_do_escopo_da_função">Variável global implícita e fora do escopo da função</h3> + +<p>Variáveis que aparecem como variáveis globais implicitas podem ser referenciadas como variáveis fora do escopo da função:</p> + +<pre class="brush: js">var x = 0; // x é declarada como global e é igual a 0 + +console.log(typeof z); // undefined, desde que z não tenha sido criada anteriormente + +function a() { // quando a for chamada, + var y = 2; // y é declarada como local desta função, e o valor 2 é atribuido + + console.log(x, y); // 0 2 + + function b() { // quando b for chamado, + x = 3; // atribui o valor 3 a variável global existente, ele não cria uma nova variável global + y = 4; // atribui o valor 4 a uma variável fora, ele não cria uma nova variável + z = 5; // cria uma nova variável global e atribui o valor 5. + } // (Lança a exceção ReferenceError em modo restrito.) + + b(); // chamando b, o código irá criar z como variável global + console.log(x, y, z); // 3 4 5 +} + +a(); // chamando a, também irá chamar b +console.log(x, z); // 3 5 +console.log(typeof y); // indefinido já que y é uma variável local da função a</pre> + +<h2 id="Especificação">Especificação</h2> + +<table class="standard-table"> + <tbody> + <tr> + <th scope="col">Specification</th> + <th scope="col">Status</th> + <th scope="col">Comment</th> + </tr> + <tr> + <td>ECMAScript 1st Edition</td> + <td>Standard</td> + <td>Primeira definição.<br> + Implementada no JavaScript 1.0</td> + </tr> + <tr> + <td>{{SpecName('ES5.1', '#sec-12.2', 'var statement')}}</td> + <td>{{Spec2('ES5.1')}}</td> + <td> </td> + </tr> + <tr> + <td>{{SpecName('ES6', '#sec-variable-statement', 'variable statement')}}</td> + <td>{{Spec2('ES6')}}</td> + <td> </td> + </tr> + </tbody> +</table> + +<h2 id="Compatibilidade_dos_Navegadores">Compatibilidade dos Navegadores</h2> + +<p>{{ CompatibilityTable() }}</p> + +<div id="compat-desktop"> +<table class="compat-table"> + <tbody> + <tr> + <th>Feature</th> + <th>Chrome</th> + <th>Firefox (Gecko)</th> + <th>Internet Explorer</th> + <th>Opera</th> + <th>Safari</th> + </tr> + <tr> + <td>Basic support</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + </tr> + </tbody> +</table> +</div> + +<div id="compat-mobile"> +<table class="compat-table"> + <tbody> + <tr> + <th>Feature</th> + <th>Android</th> + <th>Chrome for Android</th> + <th>Firefox Mobile (Gecko)</th> + <th>IE Mobile</th> + <th>Opera Mobile</th> + <th>Safari Mobile</th> + </tr> + <tr> + <td>Basic support</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + <td>{{ CompatVersionUnknown() }}</td> + </tr> + </tbody> +</table> +</div> + +<h2 id="See_also" name="See_also">Veja também</h2> + +<ul> + <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/let"><code>let</code></a></li> + <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/const"><code>const</code></a></li> + <li><a class="external" href="http://blog.safeshepherd.com/23/how-one-missing-var-ruined-our-launch/">How One Missing `var` Ruined our Launch</a></li> +</ul> |