quinta-feira, 29 de julho de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos
Fazendo uma combo dinâmica com Jquery
Por: Magno Costa
[Entre em contato com o autor ]
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Fazendo uma combo dinâmica com Jquery
Publicado em: 26/01/2010

Lá vai meu segundo tutorial aqui no Linha de Código. Hoje no meu trabalho um estagiário me perguntou como criar uma página que adiciona e remove combo de acordo com a necessidade do usuário.

Bom é importante citar que irei trabalhar com o jquery.

 

O primeiro passo será criar o nosso html para fazer isso, utilizei uma página bem limpa para fixar bem a idéia do tutorial.

 

Ai vai nosso html bem simples já com o jquery importado.

 

<html>

            <head>

                        <title>Aprendendo Jquery</title>

                        <script language="javaScript" src="javaScript/jquery.js"></script>

            </head>

            <body>

                        <table>

                                   <tr>

                                               <td>Selecione uma pessoa</td>

                                               <td>

                                                           <select>

                                                                       <option value="magno">Magno</option>

                                                                       <option value="michell">Michell</option>

                                                                       <option value="douglas">Douglas</option>

                                                           </select>

                                               </td>

                                               <td>

                                                           <input type="button" value="+" id="adcionar" />

                                                           <input type="button" value="-" id="remover" />

                                               </td>

                                   </tr>

                        </table>                     

            </body>

</html>

 

Acho que aqui não preciso explicar nada, só criei um html e adicionei uma tabela com uma linha que tem um botão para o usuário poder fazer a seleção desejada.

Adicionei um botão para caso o usuário deseje acrescentar uma nova caixa de seleção.

 

 

Exemplo:

 

 

 

Vamos ao javascript agora?!!!

 

Bom ai vai o código fonte.

 

 

$(document).ready(function(){

           

            $("#adcionar").click(function(){

                       

                        $("tr:last").after("<tr>"+$("tr:last").html()+"</tr>")

                        $("td:last").empty()

 

 

            })

 

            $("#remover").click(function(){

 

                        if($("tr").length == 1){

                                   alert("nao e possível remover todas as combos")

                        }else{

                                   $("tr:last").remove();

                        }

 

            })

           

 

})

 

 

 

Bom na primeira linha coloco uma ação relacionada ao evento carregar página, ou seja, o código javascript só será executado depois que toda a página html estiver sido carregada, para não termos problemas de referenciar um objeto no javascript que ainda não existe em nosso contexto.

 

ex:

            $(document).ready()

 

O próximo passo é pegar o botão da página que tem como atributo id a palavra  adicionar e criar um evento para esse botão, ou seja quando o boato for clicado (click) ele executará as ações abaixo.

 

ex:

            $("#adcionar").click()

 

Quando o botão adicionar receber um click será efetuada uma busca na última tr do meu código, quando esta for encontrada, adiciono o mesmo conteúdo da tr anterior.

 

ex:

            $("#tr:last").after()

 

 

Se nosso script parasse a execução nesse momento teríamos uma tabela html assim:

 

                        <table>

                                   <tr>

                                               <td>Selecione uma pessoa</td>

                                               <td>

                                                           <select>

                                                                       <option value="magno">Magno</option>

                                                                       <option value="michell">Michell</option>

                                                                       <option value="douglas">Douglas</option>

                                                           </select>

                                               </td>

                                               <td>

                                                           <input type="button" value="+" id="adcionar" />

                                                           <input type="button" value="-" id="remover" />

                                               </td>

                                   </tr>

                                   <tr>

                                               <td>Selecione uma pessoa</td>

                                               <td>

                                                           <select>

                                                                       <option value="magno">Magno</option>

                                                                       <option value="michell">Michell</option>

                                                                       <option value="douglas">Douglas</option>

                                                           </select>

                                               </td>

                                               <td>

                                                           <input type="button" value="+" id="adcionar" />

                                                           <input type="button" value="-" id="remover" />

                                               </td>

                                   </tr>

                        </table>

 

Repare que a nova linha foi adicionada perfeitamente, porem eu não gostei do fato do botão adicionar e remover fica aparecendo toda hora, então eu removi esses botões deixando disponíveis somente na primeira linha.

 

Ex

 

            $("td:last").empty()

 

Com o comando acima eu procurei a última td do meu código e limpei o conteúdo dela.

 

Até aqui nosso código esta ok já esta adicionando perfeitamente, agora só falta remover que é o mais fácil de todos.

Primeiro coloco uma evento relacionado ao botão que tem como atributo com o valor remover.

 

ex:

            $("#remover").click()

 

Quando o botão remover for clicado verifico se existe mais de uma linha na minha página, se não tiver, não vou permitir que o usuário remova a única linha da página.

 

ex:

 

            if($("tr").length == 1){

                        alert("nao e possível remover todas as combos")

            }                     

 

Agora se existir mais de uma linha na minha página eu posso permitir que o usuário remova sendo assim:

 

                        else{

                                   $("tr:last").remove();

                        }

 

 

Tá aí galera, desculpe se ficou um pouco grande o tutorial.

 

Tutorial dedicado ao meu estagiário Douglas Ribeiro mais conhecido na FOA como 10.

 

Abração galera !!!!

 

 

"Pensou em Jquery, pensou no simples !”





Windows Server 2008 Foundation



 

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Ainda não existem comentários sobre este artigo. Seja o(a) primeiro(a)!
Outros artigos do autor Topo
Fazendo um simples upload de arquivo com php
Artigos relacionados Topo
Autenticação com WCF e jQuery
Tratando erros com jQuery e WCF
Utilizando jQuery para invocar Actions
Consumindo serviços WCF com jQuery
JQuery auto complete em Asp.Net
Preenchendo completamente as colunas na vertical em um layout tableless
Gerando JavaScript do lado do servidor com ASP.NET
Namespace em Javascript é possível?
JSON – Uma introdução
Galeria de Imagens com C#, Asp.NET e jQuery
Recorte de Imagens com C#, Asp.NET e jQuery
Acessando funções JavaScript pelo Silverlight (C#)
Iniciando em jQuery
jQuery — Seletores e estilização
Introdução à jQuery
Aprendendo e Entendendo o AJAX
Selecionando Linhas de forma dinâmica dentro do GridView
Search do Windows Live em seu site
Passando um dataset do ASP.NET para o Javascript
Acessibilidade: Aumentando e Diminuindo Tamanho de Letra em seu site
Gráfico em barra com javascript
Experimentando o Intellisense para Javascript do Visual Studio 2008
Debugando código em Javascript no Visual Studio 2008
Como chamar uma função server-side utilizando Javascript e ASP.NET Ajax 1.0
Javascript: Construindo um editor de texto
Javascript: O Objeto Date()
Implementando um Pilha com JavaScript
O objeto XMLHttpRequest
Utilizando AJAX com ASP.Net
Expressões Regulares - continuação
Produtos relacionados Topo
Livro: Guia de Orientação e Desenvolvimento de Sites - HTML, XHTML, CSS e JavaScript/JScript
Livro: AJAX - Guia de Programação
Livro: AJAX - Guia Prático para Windows
Livro: ASP.NET Guia do Desenvolvedor
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 2.488
Artigos: 2.972
Cases: 14
Oportunidades: 4.546
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
O que você fará com o Visual Studio 2010?
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
De: R$ 189,00
Por: R$ 126,00
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção C# Básico (válido somente para pagamento via boleto bancário)
De: R$ 185,90
Por: R$ 136,00
Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
De: R$ 308,00
Por: R$ 219,00
Promoção Especial Infra
De: R$ 175,95
Por: R$ 136,00
CDs/DVDs
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
Por: R$ 59,00
DVD Curso de CorelDraw X4
Por: R$ 79,90
DVD Curso de Fireworks CS4
Por: R$ 49,90
DVD Curso de Indesign CS4
Por: R$ 55,00
DVD Curso de Efeitos Digitais
Por: R$ 49,90
Livros
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
De: R$ 129,00
Por: R$ 77,40
Foundation FLASH CS3 para Designers
Ciência Moderna
De: R$ 139,00
Por: R$ 83,40
Recursos Visuais na Web com PHP
Ciência Moderna
De: R$ 49,00
Por: R$ 29,40
Crie um Sistema Web com PHP 5 e AJAX - Controle de Estoque
Erica
De: R$ 99,50
Por: R$ 84,50
Crie Projetos Gráficos com Adobe Photoshop CS4, CorelDRAW X4 e Adobe InDesign CS4 - em Português
Erica
De: R$ 77,50
Por: R$ 65,80
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Anderson Patricio
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
José Carlos Macoratti
Eric C M Oliveira
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Excel: fórmulas matriciais
ASP.NET 2.0 - Explorando o GridView
Iniciando um projeto de Nota Fiscal Eletrônica - NFe
PL/SQL - Procedures e Funções
Excel: Comparando Listas
PHP: Formulários e upload de múltiplos arquivos e fotos