Pular para o conteúdo principal

Limpando objetos dinamicamente (Delphi)

 

Muitas vezes nos deparamos com situações onde devemos remover o conteúdo de determinados objetos, como por exemplo Edits ou mesmo Labels e dependendo da complexidade da tela setar manualmente cada campo pode ser trabalhoso.Sendo assim mostraremos hoje como montar um esquema automático e genérico para esse caso:

 

procedure TForm1.Button1Click(Sender: TObject); 

procedure LimparEdits(AControl: TComponent);
var
   vLoop: Integer;
begin

    { ComponentCount retorna a qtde de componentes que o parent é o AControl, ou seja, somente os componentes que
    estão ligados a ele }

    for vLoop := 0 to AControl.ComponentCount-1 do 
    begin                                                

           { Se for um componente do tipo TEdit, }     
            { então iremos limpar o conteúdo, caso }
            { contrário, iremos rechamar a procedure }
            { pois o AControl pode ser um painel e temos }
            { que limpar inclusive os edits do painel }

            if AControl.Components[vLoop].ClassType = TEdit then
               TEdit(AControl.Components[vLoop]).Clear        
                else
               LimparEdits(AControl.Components[vLoop]);  

    end;

end;  

begin  

    { O processo irá iniciar limpando os edits que estão diretamente  docados no form }

    LimparEdits(Self);

end;

Comentários

  1. Oi Du, olha eu aqui outra vez! (hehe)
    Adivinha porque estou aqui?
    Selos, meu caro amigo, tem um pra vc lá no HISTOBLOG, desculpa aí Du, mas vai ter que aguentar mais esse.
    Inté amigo,
    Fui

    ResponderExcluir
  2. Olá Susi, assim que eu tiver um tempinho eu posto, bjos...

    ResponderExcluir
  3. Oi Du, kd você?
    Tá sumido! A vida tá corrida?
    Espero que esteja tudo na paz.
    Não se incomode com o post do selo, quando puder vc faz.
    Só passei pra dar um OI.
    Oi Du! Tchau Du! (chata pra caramba hehe)
    Inté

    ResponderExcluir
  4. Preciso de uma ajuda, to com um panel e quero abrir mais de um form nele alternadamente, estou usando o parent para a abrir os forms, o problema e que quando click em um botão para abrir um form no panel ele abre normalmente, quando vou abrir o outro tanbem abre normalmente, só que quando vou tentetar reabrir o primeiro naum abre, tb n abre o segundo, espero ajuda

    qualquer coisa me responda pelo email plix
    leonardo.oo.18@hotmail.com

    ResponderExcluir
  5. Susi realmente estou bem enrolado, mas hoje eu posto seu selo, hehe bjos...

    Meu amigo Leo, vou ver se monto um exemplo entre hoje e amanhã e posto aqui no blog, abraços...

    ResponderExcluir
  6. Leo eu fiz um pequeno exemplo e me parece que o erro que você esta recebendo tem a ver com a criação de forms com o mesmo nome, por isso só da problema na segunda vez, lembre-se que cada objeto deve possuir uma identificação única, logo se voce precisa criar dinamicamente o mesmo form mais de uma vez será necessário criar uma funcionalidade que a cada criação gere um nome diferente, armazene os nomes utilizados ou gere uma string "randomica", se precisar de mais detalhes pode perguntar, abraços...

    ResponderExcluir
  7. Olá amigo blogueiro, também tenho um blog, e desenvolvi uma ferramenta para postar os códigos delphi de forma mais elegante.
    Se tiver interesse da uma olhada no meu blog que tem um link para baixar a ferramente com código fonte.

    http://dsutil.blogspot.com/2009/11/convertendo-codigo-delphi-para-html.html

    Abraço!

    ResponderExcluir

Postar um comentário

Obrigado por Participar do programero, fique a vontade para agradecer, retificar, perguntar ou sugerir.

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

Manipular arquivos com PL/SQL (Oracle)

O bom e velho arquivo, é impressionante como lidamos com seus vários tipos durante todos os dias, bom hoje vamos mostrar um jeito simples de se escrever e ler arquivos apenas com a codificação nativa do Oracle. A primeira coisa a fazer é criar um diretório válido configurado no Oracle, e permissões de acesso a esse diretório para o usuário de banco onde faremos o exemplo, sendo assim suponhamos que nosso usuário de banco se chame programero, e nosso diretório real esteja em c:\programero, então logado como SYSTEM devemos executar os seguintes comandos: 1: -- cria diretorio 2: create or replace directory DIR_PROGRAMERO as ' C:\PROGRAMERO '; 3: -- concede permissão de escrita e leitura para nosso usuário 4: grant read , write on directory DIR_PROGRAMERO to PROGRAMERO; Para escrever, basicamente precisamos apenas saber onde esse arquivo ficará, no nosso caso no diretório criado acima, segue o código de escrita: 1: declare 2: -- nosso handler 3: v_a...

Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker

Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker Neste guia, vamos criar uma aplicação básica que acessa um banco de dados PostgreSQL e realiza operações CRUD (Create, Read, Update, Delete). Vamos usar Flask e executar tudo com Docker. Sem estilos ou extras, apenas o essencial. Estrutura do Projeto crud-app/ |-- app/ | |-- app.py | |-- templates/ | | |-- index.html | | |-- edit.html |-- Dockerfile |-- requirements.txt |-- docker-compose.yml Passo 1: Dependências Crie um arquivo requirements.txt com as seguintes linhas: Flask==2.2.2 Flask-SQLAlchemy==3.0.2 psycopg2-binary==2.9.3 Werkzeug==2.2.2 Passo 2: Aplicação Flask Arquivo app/app.py : from flask import Flask, render_template, request, redirect, url_for from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # Configuração do banco de dados app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://user:password@db:5432/crud_db' app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False db...