Pular para o conteúdo principal

JS - Funções

Quando precisamos armazenar uma rotina de modo que um mesmo trecho de código possa ser executado diversas vezes sem a necessidade de repetição da codificação lançamos mão desse artificio, também muito comum entre as mais diversas linguagens de programação.

No Javascript sua criação e utilização são muito comuns, podemos dizer que não existem aplicações reais sem funções, logo nesse primeiro contato destacaremos algumas de suas principais características:

Definição

Por definição, uma função é um bloco de código nomeado que pode ser executado a partir do operador "()".

Estrutura

Possui como estrutura minima a palavra reservada "function" o "nome" utilizado para sua identificação, seguido do operador "()" e um bloco de conteúdo, determinado por "{}".

function soma() {}

É importante destacar aqui que, para utilizar uma função devemos obrigatoriamente saber seu nome e utilizar o operador de execução, ou seja, para executarmos uma função cujo nome seja "soma" precisaríamos digitar: 

soma()

Vale ressaltar que no exemplo acima nossa função não faz nada, uma vez que seu bloco de código, delimitado por "{}" esta vazio.

Escopo

Podemos considerar como escopo o domínio sobre determinados recursos, ou seja, quando falamos que uma função possui escopo estamos afirmando que tudo aquilo que esta codificado na função pertence apenas a ela, não sendo possível acessar externamente.
Para exemplificar vamos considerar o exemplo abaixo:

function novaSoma() {
    var resultado = 1 + 2;
}

Sobre a função acima:

  • Perceba o uso do ";", ele determina o encerramento de uma instrução, ou seja, na função "novaSoma" temos uma instrução a ser executada;
  • Temos dentro do escopo da função "novaSoma" a variável "resultado", se tentarmos acessar essa variável não conseguiremos pois ela pertence a um escopo definido, podendo ser acessado apenas dentro desse escopo;
  • Se tentarmos executar a função "novaSoma" temos como resultado o valor "undefined" pois essa função não nos retorna nada;
  • Se tentarmos acessar a variável "resultado" temos um erro pois não temos acesso ao escopo da função;


Retorno

Na maioria dos casos sempre teremos uma função que, alem de executar uma instrução também nos retornara o resultado da mesma, é ai que entra a palavra reservada "return":

function outraSoma() {
    var resultado = 1 + 2;
    return resultado;
}

Sobre a função acima:

  • A nova função tem duas instruções a serem executadas, a soma dos números "1" e "2" armazenada na variável "resultado" e o retorno do valor contido na variável "resultado";
  • Ao executar a função temos como resultado o valor "3";
  • Mesmo recebendo o valor da variável "resultado" continuamos sem a capacidade de manipular a mesma pois o escopo continua pertencente a função;


Argumentos ou parâmetros

Outro recurso muito importante das funções é a capacidade de receber valores a serem processados, com isso temos funções que são capazes de produzir resultados diferentes de acordo com a parametrização recebida:

function somarDoisNumeros(a, b) {
    var resultado = a + b;
    return resultado;
}

Sobre a função acima:
  • Agora, além do nome da função também precisamos informar valores para os parâmetros, dentro do operador de execução (em nosso exemplo, caso os parâmetros não sejam informados temos como resultado "NaN" (not a number), pois variáveis que não são números passarão por uma execução, soma, que exige o uso de números);
  • Dessa forma temos uma rotina que pode ser reutilizada sempre que for necessário saber o resultado da soma de dois valores;

Comentários

Mais visitadas

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 ...

Alterar cores do PageControl (Delphi)

O padrão Windows todo cinza não é muito atraente, por isso quando nos utilizarmos do PageControl podemos alterar suas cores e fontes da seguinte maneira: Em primeiro lugar devemos alterar a propriedade OwnerDraw para TRUE ; Depois implementar seu método DrawTab da seguinte maneira: //pinta a fonte Control.Canvas.Font.Color:=clBlack; // // pinta a paleta / aba Control.Canvas.brush.Color:=clSkyBlue; PageControl1.Canvas.Rectangle(Rect); Control.Canvas.TextOut(Rect.left+5,Rect.top+3,PageControl1.Pages[tabindex].Caption); // pinta a parte interna (tabsheet) PageControl1.Pages[TabIndex].brush.Color := Control.Canvas.brush.Color; PageControl1.Pages[TabIndex].Repaint; Caso a intenção seja manter cada aba com seu próprio estilo basta adicionar um CASE filtrando o índice das abas: case TabIndex of   0: Control.Canvas.Font.Color:=clBlack;   1: Control.Canvas.Font.Color:=clWindow; ...

Como Verificar se um Objeto Existe (Delphi)

Em alguns momentos surge a necessidade de verificar se um determinado objeto existe, ou seja se já foi criado, principalmente quando se trabalha com criação dinâmica em tempo de execução, então vamos ao exemplo: - Vamos criar uma variável, um vetor do tipo caixa de texto: var Minha_caixa : array of TEdit; - Em seguida definir o tamanho desse vetor, no caso será dez: setLength(Minha_caixa, 10) - Agora iremos criar nossa caixa de texto: // lembrando que o vetor inicia em zero // logo o índice final é o tamanho total - 1 for vl_i := 0 to Length(Minha_caixa) -1 do begin Minha_caixa[vl_i] := TEdit.Create(self); with Minha_caixa[vl_i] do begin Parent := Self; Name := 'Caixa_N'+IntToStr(vl_i); Text := 'Esta é a '+IntToStr(vl_i)+' º caixa !'; ReadOnly := true; Height := 21; Width := ...