Dúvida comum: quando eu devo usar ponto-e-vírgula no Javascript? Javascript herdou a sintaxe do ramo do Pascal e do C, com um ponto-e-vírgula ao final de cada comando. Em tese, deveria funcionar então como PHP, Java, C++ ou Delphi. Disse “em tese”, porque o ECMA incluiu um recurso na linguagem que inclui automaticamente, na hora da interpretação do código, um ponto-e-vírgula ao final de cada linha de código que não termine com ponto-e-vírgula. Isso significa que você não pode, em javascript, escrever seu comando em mais de uma linha, como pode fazer em PHP:

1
2
3
4
5
<?
$x=1
+
2;
?>

Se você seguir as recomendações do ECMA, vai escrever ponto-e-vírgula ao final de cada linha, e se esquecer de alguma o interpretador vai inseri-la automaticamente.

1
2
3
x=1;
y=2;
z=x+y;

Por outro lado, a inclusão de ponto-e-vírgula automático vai fazer com que, na prática, a linguagem se comporte de maneira muito semelhante a linguagens como Ruby ou Python, em que você só costuma usar ponto-e-vírgula quando vai digitar mais de um comando numa mesma linha. Logo, pode ser que você prefira escrever assim:

1
2
3
x=1
y=2
z=x+y

Embora alguns possam argumentar que, por ser uma recomendação do ECMA, usar ponto-e-vírgula é melhor, na verdade quem vai decidir que estilo de código é melhor para você é você mesmo. Se você é um programador PHP ou Java, e se sente melhor escrevendo os pontos-e-vírgulas, vá em frente. Se você, como eu, se sente melhor quando escreve menos código, não use o ponto-e-vírgula. A mesma coisa acontece em relação ao uso e posicionamento das chave. Veja, por exemplo, essas duas maneiras diferentes de se escrever o mesmo código:

1
2
3
4
5
6
7
8
9
10
11
function conta(x)
{
    for(var i=0;i<x;i++)
    {
        alert("Contando"+i);
        if(i%2==0)
        {
            alert("É par!");
        }
    }
}

E o jeito como eu gosto:

1
2
3
4
5
6
7
function conta(x){
    for(var i=0;i<x;i++){
        alert("Contando"+i)
        if(i%2==0)
            alert("É par!")
    }
}

Escolha o padrão que parecer mais legível para você. Só não se esqueça de tornar isso um padrão na empresa, ou pelo menos em sua equipe, de modo que todos os desenvolvedores usem a mesma sintaxe.