Pular para o conteúdo principal

JS - Javascript no browser

A partir de agora vamos ver exemplos de como usar nosso código Javascript em páginas web, hoje veremos as possibilidades para isso e também aproveitaremos o momento para exemplificar a questão do escopo de variáveis.

Estrutura minima do html

Sabemos que a estrutura base para uma página web são as tags "html", dentro dela "head" e "body", nosso código Javascript deve estar na tag "script".

A tag "script" pode ser incluída tanto dentro da tag "head" quanto dentro da tag "body", a diferença é que, quando nosso código estiver na "head" ele será carregado antes do conteúdo da página e quando nosso código estiver no "body" primeiro serão carregados os elementos "html" para em seguida nosso Javascript ser carregado.

Como podemos imaginar o forma mais indicada atualmente é a inclusão no "body", pois caso nossos scripts sejam "pesados" eles não impactarão no carregamento de nossa página.

Bom, afirmamos que nosso código Javascript vai na tag "script", podemos tanto digitar nosso código dentro da tag como podemos realizar uma referencia a um arquivo externo, sendo mais indicado a última forma, pois assim temos uma organização melhor, podendo dividir nosso código em arquivos diferentes, de acordo com seu propósito.

Para exemplificar, criaremos um arquivo "index.html", um diretório "js" e dentro desse diretório criaremos o "main.js" e o "exemplo.js". No "index.html" teremos a estrutura base de uma página e a importação desses dois arquivos de script (atentar para o detalhe da importação do script, que se dá por meio da propriedade "src" da tag "script"):



Exemplificando o escopo

Na postagem sobre IIFE - immediatley-invoked function expression nós vimos as funções autoexecutáveis e ressaltamos sua importância para proteger o escopo de variáveis, agora veremos isso na prática, primeiro criaremos uma variável no script "main.js" e mostraremos seu conteúdo no script "exemplo.js", como resultado o valor atribuído em uma classe estará disponível na outra classe, e pior, podemos alterar esse valor na outra classe:

Em "main.js"

console.log('main.js');
var nome = 'Teresa';
console.log('main.js''nome'nome);

Em "exemplo.js"

console.log('exemplo.js');
console.log('exemplo.js''nome'nome);
nome = 'Adamastor';
console.log('exemplo.js''nome'nome);

Como resultado


Como podemos ver, as consequências para isso podem ser catastróficas, podemos ter variáveis de um script sendo alteradas em outro e quando menos percebermos teremos uma série de anomalias no comportamento de nossa aplicação e teremos dificuldades para a solução.

Resolvendo o problema do escopo

Simples, basta usarmos o conceito da IIFE, nossas funções autoexecutáveis protegerão nossas variáveis e o problema de escopo estará resolvido:

Em "main.js"

(function() {
    console.log('main.js');
    var nome = 'Teresa';
    console.log('main.js''nome'nome);
})();

Em "exemplo.js"

(function() {
    console.log('exemplo.js');
    nome = 'Adamastor';
    console.log('exemplo.js''nome'nome);
})();

Como resultado



Podemos concluir, com tudo que foi visto aqui, que devemos escrever nosso código Javascript em arquivos a parte da página, que devemos importar esses arquivos na tag "script", e que a tag "script" deve estar dentro da tag "body" e que devemos mais do que nunca usar o conceito da IIFE para evitar problemas de escopo.

Comentários

Mais visitadas

Iniciar e Parar Serviços do Windows (Delphi)

Em certas ocasiões nos deparamos com a necessidade de manipular determinadas atividades do SO, como iniciar ou parar um banco de dados, ou qualquer outro serviço que esteja funcionando no momento. Segue abaixo um código que encontrei na Internet para tal finalidade (não me recordo à fonte, assim que eu a encontrar colocarei). Iniciar Serviço: uses WinSvc; // // start service // // return TRUE if successful // // sMachine: //   machine name, ie: \SERVER //   empty = local machine // // sService //   service name, ie: Alerter // function ServiceStart(   sMachine,   sService : string ) : boolean; var   //   // service control   // manager handle   schm,   //   // service handle   schs   : SC_Handle;   //   // service status   ss     : TServiceStatus;   //   // te...

Listar arquivos existentes em diretório (Delphi)

Mostraremos uma maneira simples e prática para listar o conteúdo de um diretório com a opção de incluir nessa listagem os arquivos de seus subdiretórios. No exemplo abaixo temos um Edit para receber o diretório a ser pesquisado um CheckBox para indicar se os subdiretórios entrarão na pesquisa um botão para efetuar a pesquisa e um Memo para listar os arquivos encontrados, no final um Edit que receberá o cálculo final (em bytes) da soma do tamanho dos arquivos. procedure TForm1.Button1Click(Sender: TObject); begin   tamanhoTotal := 0;   memLista.Lines.Clear;   ListarArquivos(edtDiretorio.Text, chkSub.Checked);   Edit1.Text := IntToStr( tamanhoTotal ); end; procedure TForm1.ListarArquivos(Diretorio: string; Sub:Boolean); var   F: TSearchRec;   Ret: Integer;   TempNome: string; begin   Ret := FindFirst(Diretorio+'\*.*', faAnyFile, F);   try     while Ret = 0 do ...

Centralizar Texto em Edit

Como todos sabemos o Edit mantém todo texto digitado a esquerda, o que não fica bem quando o usamos para a entrada de números, pois bem, o exemplo abaixo apresenta uma alternativa para centralizar um determinado valor dentro de um Edit: procedure EditChange(Sender: TObject); var vl_label : TLabel; //variável do tipo Label begin vl_label := TLabel.Create(self); //criamos um label WITH vl_label DO BEGIN Font.Name := TEdit(sender).Font.Name; //pegamos a fonte usada no edit Caption := TEdit(sender).Text; //pegamos o conteúdo do edit SendMessage(TEdit(sender).Handle, EM_SETMARGINS, EC_LEFTMARGIN, (TEdit(sender).Width-vl_label.Width) div 2); //centraliza no label e retorna para o edit END ; vl_label.Free; end ;