Criando e deslocando elementos DOM
Depois de muito tempo, estou de volta!
Hoje vou falar de uma dica, que muitos irão achar idiota, outros não. Esses lances de DOM, são muito massa né?! Só que eu sou meio burrinho (rs). Enfim, é algo bem simples, porém nunca tinha me dado conta o quão simples era. Em DOM têm-se o comando:
O comando acima, cria um elemento html, porém em todos os exemplos que vi na internet até hoje, esse comando era seguido disso:
OU
Sempre interpretei que os códigos acimas, "cria-se" um elemento dentro do elemento com id de meuElemento, não tinha dúvidas quanto à esse conceito. Porém, ledo engano meu caro, o elemento já tinha sido criado, portanto nesses dois códigos acima, só foram feitos os "deslocamentos" dos elementos. Pensando dessa forma, um monte de coisas que tinha grande dificuldade de fazer, pois se tornavam extensos, podem ser feitos bem rápidos, segue um exemplo muito bom:
Você tem uma aplicação que em um determinado momento, dependendo da iteração com o usuário, o mesmo pega um elemento que é filho de um "pai" e muda de lugar, acarretando na mudança de pai. O que eu um méris mortal fazia?
Sempre soube que a propriedade parentNode, era apenas de leitura. =/
Se eu não posso mudar o "pai", só me resta criar um outro elemento com o pai desejado, mas que tenham os mesmos atributos, com isso acarretava de eu usar, um cloneChild com o "pai" diferente e depois fazer um removeChild.
Viu o trabalhão? Duplico o elemento que eu quero, jogo no pai desejado e excluo o elemento que pertence ao pai que não desejo mais.
Mas com o conceito que falei anteriormente, Seus problemas acabaram. (com muito mais échio) [Concordo contigo, estou no fundo do poço, citar Casseta & Planeta, ninguém merece]
Não preciso de mais nada disso, posso resolver o meu problema direto com o appendChild ou insertBefore, como eles não são os responsáveis pela criação do elemento e sim, apenas, pelo "deslocamento", ou seja, desloco o meu elemento para o pai desejado e pronto.
Viu? Ficou muito mais simples.
"Coisas simples devem parecer simples, coisas complexas devem parecer possíveis."
Obs1: Eu não entrei em maiores detalhes sobre a diferença entre o insertBefore e appendChild, pois esse não era o foco principal desse post, mas em um próximo post, explico com maiores detalhes essas duas propriedades importantíssimas.
Desejo à todos um ótimo natal e semana que vem estou de volta! (pelo menos, assim espero)
Fuiii...
Hoje vou falar de uma dica, que muitos irão achar idiota, outros não. Esses lances de DOM, são muito massa né?! Só que eu sou meio burrinho (rs). Enfim, é algo bem simples, porém nunca tinha me dado conta o quão simples era. Em DOM têm-se o comando:
meuElem = document.createElement("elemento");
O comando acima, cria um elemento html, porém em todos os exemplos que vi na internet até hoje, esse comando era seguido disso:
document.getElementById("meuElemento").appendChild(meuElem);
OU
document.getElementById("meuElemento").insertBefore(meuElem, document.getElementById("meuElemento").lastChild);
Sempre interpretei que os códigos acimas, "cria-se" um elemento dentro do elemento com id de meuElemento, não tinha dúvidas quanto à esse conceito. Porém, ledo engano meu caro, o elemento já tinha sido criado, portanto nesses dois códigos acima, só foram feitos os "deslocamentos" dos elementos. Pensando dessa forma, um monte de coisas que tinha grande dificuldade de fazer, pois se tornavam extensos, podem ser feitos bem rápidos, segue um exemplo muito bom:
Você tem uma aplicação que em um determinado momento, dependendo da iteração com o usuário, o mesmo pega um elemento que é filho de um "pai" e muda de lugar, acarretando na mudança de pai. O que eu um méris mortal fazia?
Sempre soube que a propriedade parentNode, era apenas de leitura. =/
Se eu não posso mudar o "pai", só me resta criar um outro elemento com o pai desejado, mas que tenham os mesmos atributos, com isso acarretava de eu usar, um cloneChild com o "pai" diferente e depois fazer um removeChild.
Viu o trabalhão? Duplico o elemento que eu quero, jogo no pai desejado e excluo o elemento que pertence ao pai que não desejo mais.
Mas com o conceito que falei anteriormente, Seus problemas acabaram. (com muito mais échio) [Concordo contigo, estou no fundo do poço, citar Casseta & Planeta, ninguém merece]
Não preciso de mais nada disso, posso resolver o meu problema direto com o appendChild ou insertBefore, como eles não são os responsáveis pela criação do elemento e sim, apenas, pelo "deslocamento", ou seja, desloco o meu elemento para o pai desejado e pronto.
document.getElementById("newFather").appendChild(document.getElementById("child"));
Viu? Ficou muito mais simples.
"Coisas simples devem parecer simples, coisas complexas devem parecer possíveis."
Obs1: Eu não entrei em maiores detalhes sobre a diferença entre o insertBefore e appendChild, pois esse não era o foco principal desse post, mas em um próximo post, explico com maiores detalhes essas duas propriedades importantíssimas.
Desejo à todos um ótimo natal e semana que vem estou de volta! (pelo menos, assim espero)
Fuiii...
Marcadores: DHTML, Dicas, DOM, JavaScript
0 Comentários:
Postar um comentário
Assinar Postar comentários [Atom]
<< Página inicial